/*! jQuery UI - v1.9.0 - 2012-10-05 * http://jqueryui.com * Includes: jquery.ui.core.js, jquery.ui.widget.js, jquery.ui.mouse.js, jquery.ui.draggable.js, jquery.ui.droppable.js, jquery.ui.resizable.js, jquery.ui.selectable.js, jquery.ui.sortable.js, jquery.ui.effect.js, jquery.ui.accordion.js, jquery.ui.autocomplete.js, jquery.ui.button.js, jquery.ui.datepicker.js, jquery.ui.dialog.js, jquery.ui.effect-blind.js, jquery.ui.effect-bounce.js, jquery.ui.effect-clip.js, jquery.ui.effect-drop.js, jquery.ui.effect-explode.js, jquery.ui.effect-fade.js, jquery.ui.effect-fold.js, jquery.ui.effect-highlight.js, jquery.ui.effect-pulsate.js, jquery.ui.effect-scale.js, jquery.ui.effect-shake.js, jquery.ui.effect-slide.js, jquery.ui.effect-transfer.js, jquery.ui.menu.js, jquery.ui.position.js, jquery.ui.progressbar.js, jquery.ui.slider.js, jquery.ui.spinner.js, jquery.ui.tabs.js, jquery.ui.tooltip.js * Copyright 2012 jQuery Foundation and other contributors; Licensed MIT */ (function(e, t) { function i(t, n) { var r, i, o, u = t.nodeName.toLowerCase(); return "area" === u ? (r = t.parentNode, i = r.name, !t.href || !i || r.nodeName.toLowerCase() !== "map" ? !1 : (o = e("img[usemap=#" + i + "]")[0], !!o && s(o))) : (/input|select|textarea|button|object/.test(u) ? !t.disabled : "a" === u ? t.href || n : n) && s(t) } function s(t) { return !e(t).parents().andSelf().filter(function() { return e.css(this, "visibility") === "hidden" || e.expr.filters.hidden(this) }).length } var n = 0, r = /^ui-id-\d+$/; e.ui = e.ui || {}; if (e.ui.version) return; e.extend(e.ui, { version: "1.9.0", keyCode: { BACKSPACE: 8, COMMA: 188, DELETE: 46, DOWN: 40, END: 35, ENTER: 13, ESCAPE: 27, HOME: 36, LEFT: 37, NUMPAD_ADD: 107, NUMPAD_DECIMAL: 110, NUMPAD_DIVIDE: 111, NUMPAD_ENTER: 108, NUMPAD_MULTIPLY: 106, NUMPAD_SUBTRACT: 109, PAGE_DOWN: 34, PAGE_UP: 33, PERIOD: 190, RIGHT: 39, SPACE: 32, TAB: 9, UP: 38} }), e.fn.extend({ _focus: e.fn.focus, focus: function(t, n) { return typeof t == "number" ? this.each(function() { var r = this; setTimeout(function() { e(r).focus(), n && n.call(r) }, t) }) : this._focus.apply(this, arguments) }, scrollParent: function() { var t; return e.browser.msie && /(static|relative)/.test(this.css("position")) || /absolute/.test(this.css("position")) ? t = this.parents().filter(function() { return /(relative|absolute|fixed)/.test(e.css(this, "position")) && /(auto|scroll)/.test(e.css(this, "overflow") + e.css(this, "overflow-y") + e.css(this, "overflow-x")) }).eq(0) : t = this.parents().filter(function() { return /(auto|scroll)/.test(e.css(this, "overflow") + e.css(this, "overflow-y") + e.css(this, "overflow-x")) }).eq(0), /fixed/.test(this.css("position")) || !t.length ? e(document) : t }, zIndex: function(n) { if (n !== t) return this.css("zIndex", n); if (this.length) { var r = e(this[0]), i, s; while (r.length && r[0] !== document) { i = r.css("position"); if (i === "absolute" || i === "relative" || i === "fixed") { s = parseInt(r.css("zIndex"), 10); if (!isNaN(s) && s !== 0) return s } r = r.parent() } } return 0 }, uniqueId: function() { return this.each(function() { this.id || (this.id = "ui-id-" + ++n) }) }, removeUniqueId: function() { return this.each(function() { r.test(this.id) && e(this).removeAttr("id") }) } }), e("").outerWidth(1).jquery || e.each(["Width", "Height"], function(n, r) { function u(t, n, r, s) { return e.each(i, function() { n -= parseFloat(e.css(t, "padding" + this)) || 0, r && (n -= parseFloat(e.css(t, "border" + this + "Width")) || 0), s && (n -= parseFloat(e.css(t, "margin" + this)) || 0) }), n } var i = r === "Width" ? ["Left", "Right"] : ["Top", "Bottom"], s = r.toLowerCase(), o = { innerWidth: e.fn.innerWidth, innerHeight: e.fn.innerHeight, outerWidth: e.fn.outerWidth, outerHeight: e.fn.outerHeight }; e.fn["inner" + r] = function(n) { return n === t ? o["inner" + r].call(this) : this.each(function() { e(this).css(s, u(this, n) + "px") }) }, e.fn["outer" + r] = function(t, n) { return typeof t != "number" ? o["outer" + r].call(this, t) : this.each(function() { e(this).css(s, u(this, t, !0, n) + "px") }) } }), e.extend(e.expr[":"], { data: e.expr.createPseudo ? e.expr.createPseudo(function(t) { return function(n) { return !!e.data(n, t) } }) : function(t, n, r) { return !!e.data(t, r[3]) }, focusable: function(t) { return i(t, !isNaN(e.attr(t, "tabindex"))) }, tabbable: function(t) { var n = e.attr(t, "tabindex"), r = isNaN(n); return (r || n >= 0) && i(t, !r) } }), e(function() { var t = document.body, n = t.appendChild(n = document.createElement("div")); n.offsetHeight, e.extend(n.style, { minHeight: "100px", height: "auto", padding: 0, borderWidth: 0 }), e.support.minHeight = n.offsetHeight === 100, e.support.selectstart = "onselectstart" in n, t.removeChild(n).style.display = "none" }), e.fn.extend({ disableSelection: function() { return this.bind((e.support.selectstart ? "selectstart" : "mousedown") + ".ui-disableSelection", function(e) { e.preventDefault() }) }, enableSelection: function() { return this.unbind(".ui-disableSelection") } }), e.extend(e.ui, { plugin: { add: function(t, n, r) { var i, s = e.ui[t].prototype; for (i in r) s.plugins[i] = s.plugins[i] || [], s.plugins[i].push([n, r[i]]) }, call: function(e, t, n) { var r, i = e.plugins[t]; if (!i || !e.element[0].parentNode || e.element[0].parentNode.nodeType === 11) return; for (r = 0; r < i.length; r++) e.options[i[r][0]] && i[r][1].apply(e.element, n) } }, contains: e.contains, hasScroll: function(t, n) { if (e(t).css("overflow") === "hidden") return !1; var r = n && n === "left" ? "scrollLeft" : "scrollTop", i = !1; return t[r] > 0 ? !0 : (t[r] = 1, i = t[r] > 0, t[r] = 0, i) }, isOverAxis: function(e, t, n) { return e > t && e < t + n }, isOver: function(t, n, r, i, s, o) { return e.ui.isOverAxis(t, r, s) && e.ui.isOverAxis(n, i, o) } }) })(jQuery), function(e, t) { var n = 0, r = Array.prototype.slice, i = e.cleanData; e.cleanData = function(t) { for (var n = 0, r; (r = t[n]) != null; n++) try { e(r).triggerHandler("remove") } catch (s) { } i(t) }, e.widget = function(t, n, r) { var i, s, o, u, a = t.split(".")[0]; t = t.split(".")[1], i = a + "-" + t, r || (r = n, n = e.Widget), e.expr[":"][i.toLowerCase()] = function(t) { return !!e.data(t, i) }, e[a] = e[a] || {}, s = e[a][t], o = e[a][t] = function(e, t) { if (!this._createWidget) return new o(e, t); arguments.length && this._createWidget(e, t) }, e.extend(o, s, { version: r.version, _proto: e.extend({}, r), _childConstructors: [] }), u = new n, u.options = e.widget.extend({}, u.options), e.each(r, function(t, i) { e.isFunction(i) && (r[t] = function() { var e = function() { return n.prototype[t].apply(this, arguments) }, r = function(e) { return n.prototype[t].apply(this, e) }; return function() { var t = this._super, n = this._superApply, s; return this._super = e, this._superApply = r, s = i.apply(this, arguments), this._super = t, this._superApply = n, s } } ()) }), o.prototype = e.widget.extend(u, { widgetEventPrefix: t }, r, { constructor: o, namespace: a, widgetName: t, widgetBaseClass: i, widgetFullName: i }), s ? (e.each(s._childConstructors, function(t, n) { var r = n.prototype; e.widget(r.namespace + "." + r.widgetName, o, n._proto) }), delete s._childConstructors) : n._childConstructors.push(o), e.widget.bridge(t, o) }, e.widget.extend = function(n) { var i = r.call(arguments, 1), s = 0, o = i.length, u, a; for (; s < o; s++) for (u in i[s]) a = i[s][u], i[s].hasOwnProperty(u) && a !== t && (n[u] = e.isPlainObject(a) ? e.widget.extend({}, n[u], a) : a); return n }, e.widget.bridge = function(n, i) { var s = i.prototype.widgetFullName; e.fn[n] = function(o) { var u = typeof o == "string", a = r.call(arguments, 1), f = this; return o = !u && a.length ? e.widget.extend.apply(null, [o].concat(a)) : o, u ? this.each(function() { var r, i = e.data(this, s); if (!i) return e.error("cannot call methods on " + n + " prior to initialization; " + "attempted to call method '" + o + "'"); if (!e.isFunction(i[o]) || o.charAt(0) === "_") return e.error("no such method '" + o + "' for " + n + " widget instance"); r = i[o].apply(i, a); if (r !== i && r !== t) return f = r && r.jquery ? f.pushStack(r.get()) : r, !1 }) : this.each(function() { var t = e.data(this, s); t ? t.option(o || {})._init() : new i(o, this) }), f } }, e.Widget = function(e, t) { }, e.Widget._childConstructors = [], e.Widget.prototype = { widgetName: "widget", widgetEventPrefix: "", defaultElement: "
", options: { disabled: !1, create: null }, _createWidget: function(t, r) { r = e(r || this.defaultElement || this)[0], this.element = e(r), this.uuid = n++, this.eventNamespace = "." + this.widgetName + this.uuid, this.options = e.widget.extend({}, this.options, this._getCreateOptions(), t), this.bindings = e(), this.hoverable = e(), this.focusable = e(), r !== this && (e.data(r, this.widgetName, this), e.data(r, this.widgetFullName, this), this._on({ remove: "destroy" }), this.document = e(r.style ? r.ownerDocument : r.document || r), this.window = e(this.document[0].defaultView || this.document[0].parentWindow)), this._create(), this._trigger("create", null, this._getCreateEventData()), this._init() }, _getCreateOptions: e.noop, _getCreateEventData: e.noop, _create: e.noop, _init: e.noop, destroy: function() { this._destroy(), this.element.unbind(this.eventNamespace).removeData(this.widgetName).removeData(this.widgetFullName).removeData(e.camelCase(this.widgetFullName)), this.widget().unbind(this.eventNamespace).removeAttr("aria-disabled").removeClass(this.widgetFullName + "-disabled " + "ui-state-disabled"), this.bindings.unbind(this.eventNamespace), this.hoverable.removeClass("ui-state-hover"), this.focusable.removeClass("ui-state-focus") }, _destroy: e.noop, widget: function() { return this.element }, option: function(n, r) { var i = n, s, o, u; if (arguments.length === 0) return e.widget.extend({}, this.options); if (typeof n == "string") { i = {}, s = n.split("."), n = s.shift(); if (s.length) { o = i[n] = e.widget.extend({}, this.options[n]); for (u = 0; u < s.length - 1; u++) o[s[u]] = o[s[u]] || {}, o = o[s[u]]; n = s.pop(); if (r === t) return o[n] === t ? null : o[n]; o[n] = r } else { if (r === t) return this.options[n] === t ? null : this.options[n]; i[n] = r } } return this._setOptions(i), this }, _setOptions: function(e) { var t; for (t in e) this._setOption(t, e[t]); return this }, _setOption: function(e, t) { return this.options[e] = t, e === "disabled" && (this.widget().toggleClass(this.widgetFullName + "-disabled ui-state-disabled", !!t).attr("aria-disabled", t), this.hoverable.removeClass("ui-state-hover"), this.focusable.removeClass("ui-state-focus")), this }, enable: function() { return this._setOption("disabled", !1) }, disable: function() { return this._setOption("disabled", !0) }, _on: function(t, n) { n ? (t = e(t), this.bindings = this.bindings.add(t)) : (n = t, t = this.element); var r = this; e.each(n, function(n, i) { function s() { if (r.options.disabled === !0 || e(this).hasClass("ui-state-disabled")) return; return (typeof i == "string" ? r[i] : i).apply(r, arguments) } typeof i != "string" && (s.guid = i.guid = i.guid || s.guid || e.guid++); var o = n.match(/^(\w+)\s*(.*)$/), u = o[1] + r.eventNamespace, a = o[2]; a ? r.widget().delegate(a, u, s) : t.bind(u, s) }) }, _off: function(e, t) { t = (t || "").split(" ").join(this.eventNamespace + " ") + this.eventNamespace, e.unbind(t).undelegate(t) }, _delay: function(e, t) { function n() { return (typeof e == "string" ? r[e] : e).apply(r, arguments) } var r = this; return setTimeout(n, t || 0) }, _hoverable: function(t) { this.hoverable = this.hoverable.add(t), this._on(t, { mouseenter: function(t) { e(t.currentTarget).addClass("ui-state-hover") }, mouseleave: function(t) { e(t.currentTarget).removeClass("ui-state-hover") } }) }, _focusable: function(t) { this.focusable = this.focusable.add(t), this._on(t, { focusin: function(t) { e(t.currentTarget).addClass("ui-state-focus") }, focusout: function(t) { e(t.currentTarget).removeClass("ui-state-focus") } }) }, _trigger: function(t, n, r) { var i, s, o = this.options[t]; r = r || {}, n = e.Event(n), n.type = (t === this.widgetEventPrefix ? t : this.widgetEventPrefix + t).toLowerCase(), n.target = this.element[0], s = n.originalEvent; if (s) for (i in s) i in n || (n[i] = s[i]); return this.element.trigger(n, r), !(e.isFunction(o) && o.apply(this.element[0], [n].concat(r)) === !1 || n.isDefaultPrevented()) } }, e.each({ show: "fadeIn", hide: "fadeOut" }, function(t, n) { e.Widget.prototype["_" + t] = function(r, i, s) { typeof i == "string" && (i = { effect: i }); var o, u = i ? i === !0 || typeof i == "number" ? n : i.effect || n : t; i = i || {}, typeof i == "number" && (i = { duration: i }), o = !e.isEmptyObject(i), i.complete = s, i.delay && r.delay(i.delay), o && e.effects && (e.effects.effect[u] || e.uiBackCompat !== !1 && e.effects[u]) ? r[t](i) : u !== t && r[u] ? r[u](i.duration, i.easing, s) : r.queue(function(n) { e(this)[t](), s && s.call(r[0]), n() }) } }), e.uiBackCompat !== !1 && (e.Widget.prototype._getCreateOptions = function() { return e.metadata && e.metadata.get(this.element[0])[this.widgetName] }) } (jQuery), function(e, t) { var n = !1; e(document).mouseup(function(e) { n = !1 }), e.widget("ui.mouse", { version: "1.9.0", options: { cancel: "input,textarea,button,select,option", distance: 1, delay: 0 }, _mouseInit: function() { var t = this; this.element.bind("mousedown." + this.widgetName, function(e) { return t._mouseDown(e) }).bind("click." + this.widgetName, function(n) { if (!0 === e.data(n.target, t.widgetName + ".preventClickEvent")) return e.removeData(n.target, t.widgetName + ".preventClickEvent"), n.stopImmediatePropagation(), !1 }), this.started = !1 }, _mouseDestroy: function() { this.element.unbind("." + this.widgetName), this._mouseMoveDelegate && e(document).unbind("mousemove." + this.widgetName, this._mouseMoveDelegate).unbind("mouseup." + this.widgetName, this._mouseUpDelegate) }, _mouseDown: function(t) { if (n) return; this._mouseStarted && this._mouseUp(t), this._mouseDownEvent = t; var r = this, i = t.which === 1, s = typeof this.options.cancel == "string" && t.target.nodeName ? e(t.target).closest(this.options.cancel).length : !1; if (!i || s || !this._mouseCapture(t)) return !0; this.mouseDelayMet = !this.options.delay, this.mouseDelayMet || (this._mouseDelayTimer = setTimeout(function() { r.mouseDelayMet = !0 }, this.options.delay)); if (this._mouseDistanceMet(t) && this._mouseDelayMet(t)) { this._mouseStarted = this._mouseStart(t) !== !1; if (!this._mouseStarted) return t.preventDefault(), !0 } return !0 === e.data(t.target, this.widgetName + ".preventClickEvent") && e.removeData(t.target, this.widgetName + ".preventClickEvent"), this._mouseMoveDelegate = function(e) { return r._mouseMove(e) }, this._mouseUpDelegate = function(e) { return r._mouseUp(e) }, e(document).bind("mousemove." + this.widgetName, this._mouseMoveDelegate).bind("mouseup." + this.widgetName, this._mouseUpDelegate), t.preventDefault(), n = !0, !0 }, _mouseMove: function(t) { return !e.browser.msie || document.documentMode >= 9 || !!t.button ? this._mouseStarted ? (this._mouseDrag(t), t.preventDefault()) : (this._mouseDistanceMet(t) && this._mouseDelayMet(t) && (this._mouseStarted = this._mouseStart(this._mouseDownEvent, t) !== !1, this._mouseStarted ? this._mouseDrag(t) : this._mouseUp(t)), !this._mouseStarted) : this._mouseUp(t) }, _mouseUp: function(t) { return e(document).unbind("mousemove." + this.widgetName, this._mouseMoveDelegate).unbind("mouseup." + this.widgetName, this._mouseUpDelegate), this._mouseStarted && (this._mouseStarted = !1, t.target === this._mouseDownEvent.target && e.data(t.target, this.widgetName + ".preventClickEvent", !0), this._mouseStop(t)), !1 }, _mouseDistanceMet: function(e) { return Math.max(Math.abs(this._mouseDownEvent.pageX - e.pageX), Math.abs(this._mouseDownEvent.pageY - e.pageY)) >= this.options.distance }, _mouseDelayMet: function(e) { return this.mouseDelayMet }, _mouseStart: function(e) { }, _mouseDrag: function(e) { }, _mouseStop: function(e) { }, _mouseCapture: function(e) { return !0 } }) } (jQuery), function(e, t) { e.widget("ui.draggable", e.ui.mouse, { version: "1.9.0", widgetEventPrefix: "drag", options: { addClasses: !0, appendTo: "parent", axis: !1, connectToSortable: !1, containment: !1, cursor: "auto", cursorAt: !1, grid: !1, handle: !1, helper: "original", iframeFix: !1, opacity: !1, refreshPositions: !1, revert: !1, revertDuration: 500, scope: "default", scroll: !0, scrollSensitivity: 20, scrollSpeed: 20, snap: !1, snapMode: "both", snapTolerance: 20, stack: !1, zIndex: !1 }, _create: function() { this.options.helper == "original" && !/^(?:r|a|f)/.test(this.element.css("position")) && (this.element[0].style.position = "relative"), this.options.addClasses && this.element.addClass("ui-draggable"), this.options.disabled && this.element.addClass("ui-draggable-disabled"), this._mouseInit() }, _destroy: function() { this.element.removeClass("ui-draggable ui-draggable-dragging ui-draggable-disabled"), this._mouseDestroy() }, _mouseCapture: function(t) { var n = this.options; return this.helper || n.disabled || e(t.target).is(".ui-resizable-handle") ? !1 : (this.handle = this._getHandle(t), this.handle ? (e(n.iframeFix === !0 ? "iframe" : n.iframeFix).each(function() { e('
').css({ width: this.offsetWidth + "px", height: this.offsetHeight + "px", position: "absolute", opacity: "0.001", zIndex: 1e3 }).css(e(this).offset()).appendTo("body") }), !0) : !1) }, _mouseStart: function(t) { var n = this.options; return this.helper = this._createHelper(t), this.helper.addClass("ui-draggable-dragging"), this._cacheHelperProportions(), e.ui.ddmanager && (e.ui.ddmanager.current = this), this._cacheMargins(), this.cssPosition = this.helper.css("position"), this.scrollParent = this.helper.scrollParent(), this.offset = this.positionAbs = this.element.offset(), this.offset = { top: this.offset.top - this.margins.top, left: this.offset.left - this.margins.left }, e.extend(this.offset, { click: { left: t.pageX - this.offset.left, top: t.pageY - this.offset.top }, parent: this._getParentOffset(), relative: this._getRelativeOffset() }), this.originalPosition = this.position = this._generatePosition(t), this.originalPageX = t.pageX, this.originalPageY = t.pageY, n.cursorAt && this._adjustOffsetFromHelper(n.cursorAt), n.containment && this._setContainment(), this._trigger("start", t) === !1 ? (this._clear(), !1) : (this._cacheHelperProportions(), e.ui.ddmanager && !n.dropBehaviour && e.ui.ddmanager.prepareOffsets(this, t), this._mouseDrag(t, !0), e.ui.ddmanager && e.ui.ddmanager.dragStart(this, t), !0) }, _mouseDrag: function(t, n) { this.position = this._generatePosition(t), this.positionAbs = this._convertPositionTo("absolute"); if (!n) { var r = this._uiHash(); if (this._trigger("drag", t, r) === !1) return this._mouseUp({}), !1; this.position = r.position } if (!this.options.axis || this.options.axis != "y") this.helper[0].style.left = this.position.left + "px"; if (!this.options.axis || this.options.axis != "x") this.helper[0].style.top = this.position.top + "px"; return e.ui.ddmanager && e.ui.ddmanager.drag(this, t), !1 }, _mouseStop: function(t) { var n = !1; e.ui.ddmanager && !this.options.dropBehaviour && (n = e.ui.ddmanager.drop(this, t)), this.dropped && (n = this.dropped, this.dropped = !1); var r = this.element[0], i = !1; while (r && (r = r.parentNode)) r == document && (i = !0); if (!i && this.options.helper === "original") return !1; if (this.options.revert == "invalid" && !n || this.options.revert == "valid" && n || this.options.revert === !0 || e.isFunction(this.options.revert) && this.options.revert.call(this.element, n)) { var s = this; e(this.helper).animate(this.originalPosition, parseInt(this.options.revertDuration, 10), function() { s._trigger("stop", t) !== !1 && s._clear() }) } else this._trigger("stop", t) !== !1 && this._clear(); return !1 }, _mouseUp: function(t) { return e("div.ui-draggable-iframeFix").each(function() { this.parentNode.removeChild(this) }), e.ui.ddmanager && e.ui.ddmanager.dragStop(this, t), e.ui.mouse.prototype._mouseUp.call(this, t) }, cancel: function() { return this.helper.is(".ui-draggable-dragging") ? this._mouseUp({}) : this._clear(), this }, _getHandle: function(t) { var n = !this.options.handle || !e(this.options.handle, this.element).length ? !0 : !1; return e(this.options.handle, this.element).find("*").andSelf().each(function() { this == t.target && (n = !0) }), n }, _createHelper: function(t) { var n = this.options, r = e.isFunction(n.helper) ? e(n.helper.apply(this.element[0], [t])) : n.helper == "clone" ? this.element.clone().removeAttr("id") : this.element; return r.parents("body").length || r.appendTo(n.appendTo == "parent" ? this.element[0].parentNode : n.appendTo), r[0] != this.element[0] && !/(fixed|absolute)/.test(r.css("position")) && r.css("position", "absolute"), r }, _adjustOffsetFromHelper: function(t) { typeof t == "string" && (t = t.split(" ")), e.isArray(t) && (t = { left: +t[0], top: +t[1] || 0 }), "left" in t && (this.offset.click.left = t.left + this.margins.left), "right" in t && (this.offset.click.left = this.helperProportions.width - t.right + this.margins.left), "top" in t && (this.offset.click.top = t.top + this.margins.top), "bottom" in t && (this.offset.click.top = this.helperProportions.height - t.bottom + this.margins.top) }, _getParentOffset: function() { this.offsetParent = this.helper.offsetParent(); var t = this.offsetParent.offset(); this.cssPosition == "absolute" && this.scrollParent[0] != document && e.contains(this.scrollParent[0], this.offsetParent[0]) && (t.left += this.scrollParent.scrollLeft(), t.top += this.scrollParent.scrollTop()); if (this.offsetParent[0] == document.body || this.offsetParent[0].tagName && this.offsetParent[0].tagName.toLowerCase() == "html" && e.browser.msie) t = { top: 0, left: 0 }; return { top: t.top + (parseInt(this.offsetParent.css("borderTopWidth"), 10) || 0), left: t.left + (parseInt(this.offsetParent.css("borderLeftWidth"), 10) || 0)} }, _getRelativeOffset: function() { if (this.cssPosition == "relative") { var e = this.element.position(); return { top: e.top - (parseInt(this.helper.css("top"), 10) || 0) + this.scrollParent.scrollTop(), left: e.left - (parseInt(this.helper.css("left"), 10) || 0) + this.scrollParent.scrollLeft()} } return { top: 0, left: 0} }, _cacheMargins: function() { this.margins = { left: parseInt(this.element.css("marginLeft"), 10) || 0, top: parseInt(this.element.css("marginTop"), 10) || 0, right: parseInt(this.element.css("marginRight"), 10) || 0, bottom: parseInt(this.element.css("marginBottom"), 10) || 0} }, _cacheHelperProportions: function() { this.helperProportions = { width: this.helper.outerWidth(), height: this.helper.outerHeight()} }, _setContainment: function() { var t = this.options; t.containment == "parent" && (t.containment = this.helper[0].parentNode); if (t.containment == "document" || t.containment == "window") this.containment = [t.containment == "document" ? 0 : e(window).scrollLeft() - this.offset.relative.left - this.offset.parent.left, t.containment == "document" ? 0 : e(window).scrollTop() - this.offset.relative.top - this.offset.parent.top, (t.containment == "document" ? 0 : e(window).scrollLeft()) + e(t.containment == "document" ? document : window).width() - this.helperProportions.width - this.margins.left, (t.containment == "document" ? 0 : e(window).scrollTop()) + (e(t.containment == "document" ? document : window).height() || document.body.parentNode.scrollHeight) - this.helperProportions.height - this.margins.top]; if (!/^(document|window|parent)$/.test(t.containment) && t.containment.constructor != Array) { var n = e(t.containment), r = n[0]; if (!r) return; var i = n.offset(), s = e(r).css("overflow") != "hidden"; this.containment = [(parseInt(e(r).css("borderLeftWidth"), 10) || 0) + (parseInt(e(r).css("paddingLeft"), 10) || 0), (parseInt(e(r).css("borderTopWidth"), 10) || 0) + (parseInt(e(r).css("paddingTop"), 10) || 0), (s ? Math.max(r.scrollWidth, r.offsetWidth) : r.offsetWidth) - (parseInt(e(r).css("borderLeftWidth"), 10) || 0) - (parseInt(e(r).css("paddingRight"), 10) || 0) - this.helperProportions.width - this.margins.left - this.margins.right, (s ? Math.max(r.scrollHeight, r.offsetHeight) : r.offsetHeight) - (parseInt(e(r).css("borderTopWidth"), 10) || 0) - (parseInt(e(r).css("paddingBottom"), 10) || 0) - this.helperProportions.height - this.margins.top - this.margins.bottom], this.relative_container = n } else t.containment.constructor == Array && (this.containment = t.containment) }, _convertPositionTo: function(t, n) { n || (n = this.position); var r = t == "absolute" ? 1 : -1, i = this.options, s = this.cssPosition != "absolute" || this.scrollParent[0] != document && !!e.contains(this.scrollParent[0], this.offsetParent[0]) ? this.scrollParent : this.offsetParent, o = /(html|body)/i.test(s[0].tagName); return { top: n.top + this.offset.relative.top * r + this.offset.parent.top * r - (this.cssPosition == "fixed" ? -this.scrollParent.scrollTop() : o ? 0 : s.scrollTop()) * r, left: n.left + this.offset.relative.left * r + this.offset.parent.left * r - (this.cssPosition == "fixed" ? -this.scrollParent.scrollLeft() : o ? 0 : s.scrollLeft()) * r} }, _generatePosition: function(t) { var n = this.options, r = this.cssPosition != "absolute" || this.scrollParent[0] != document && !!e.contains(this.scrollParent[0], this.offsetParent[0]) ? this.scrollParent : this.offsetParent, i = /(html|body)/i.test(r[0].tagName), s = t.pageX, o = t.pageY; if (this.originalPosition) { var u; if (this.containment) { if (this.relative_container) { var a = this.relative_container.offset(); u = [this.containment[0] + a.left, this.containment[1] + a.top, this.containment[2] + a.left, this.containment[3] + a.top] } else u = this.containment; t.pageX - this.offset.click.left < u[0] && (s = u[0] + this.offset.click.left), t.pageY - this.offset.click.top < u[1] && (o = u[1] + this.offset.click.top), t.pageX - this.offset.click.left > u[2] && (s = u[2] + this.offset.click.left), t.pageY - this.offset.click.top > u[3] && (o = u[3] + this.offset.click.top) } if (n.grid) { var f = n.grid[1] ? this.originalPageY + Math.round((o - this.originalPageY) / n.grid[1]) * n.grid[1] : this.originalPageY; o = u ? f - this.offset.click.top < u[1] || f - this.offset.click.top > u[3] ? f - this.offset.click.top < u[1] ? f + n.grid[1] : f - n.grid[1] : f : f; var l = n.grid[0] ? this.originalPageX + Math.round((s - this.originalPageX) / n.grid[0]) * n.grid[0] : this.originalPageX; s = u ? l - this.offset.click.left < u[0] || l - this.offset.click.left > u[2] ? l - this.offset.click.left < u[0] ? l + n.grid[0] : l - n.grid[0] : l : l } } return { top: o - this.offset.click.top - this.offset.relative.top - this.offset.parent.top + (this.cssPosition == "fixed" ? -this.scrollParent.scrollTop() : i ? 0 : r.scrollTop()), left: s - this.offset.click.left - this.offset.relative.left - this.offset.parent.left + (this.cssPosition == "fixed" ? -this.scrollParent.scrollLeft() : i ? 0 : r.scrollLeft())} }, _clear: function() { this.helper.removeClass("ui-draggable-dragging"), this.helper[0] != this.element[0] && !this.cancelHelperRemoval && this.helper.remove(), this.helper = null, this.cancelHelperRemoval = !1 }, _trigger: function(t, n, r) { return r = r || this._uiHash(), e.ui.plugin.call(this, t, [n, r]), t == "drag" && (this.positionAbs = this._convertPositionTo("absolute")), e.Widget.prototype._trigger.call(this, t, n, r) }, plugins: {}, _uiHash: function(e) { return { helper: this.helper, position: this.position, originalPosition: this.originalPosition, offset: this.positionAbs} } }), e.ui.plugin.add("draggable", "connectToSortable", { start: function(t, n) { var r = e(this).data("draggable"), i = r.options, s = e.extend({}, n, { item: r.element }); r.sortables = [], e(i.connectToSortable).each(function() { var n = e.data(this, "sortable"); n && !n.options.disabled && (r.sortables.push({ instance: n, shouldRevert: n.options.revert }), n.refreshPositions(), n._trigger("activate", t, s)) }) }, stop: function(t, n) { var r = e(this).data("draggable"), i = e.extend({}, n, { item: r.element }); e.each(r.sortables, function() { this.instance.isOver ? (this.instance.isOver = 0, r.cancelHelperRemoval = !0, this.instance.cancelHelperRemoval = !1, this.shouldRevert && (this.instance.options.revert = !0), this.instance._mouseStop(t), this.instance.options.helper = this.instance.options._helper, r.options.helper == "original" && this.instance.currentItem.css({ top: "auto", left: "auto" })) : (this.instance.cancelHelperRemoval = !1, this.instance._trigger("deactivate", t, i)) }) }, drag: function(t, n) { var r = e(this).data("draggable"), i = this, s = function(t) { var n = this.offset.click.top, r = this.offset.click.left, i = this.positionAbs.top, s = this.positionAbs.left, o = t.height, u = t.width, a = t.top, f = t.left; return e.ui.isOver(i + n, s + r, a, f, o, u) }; e.each(r.sortables, function(s) { this.instance.positionAbs = r.positionAbs, this.instance.helperProportions = r.helperProportions, this.instance.offset.click = r.offset.click, this.instance._intersectsWith(this.instance.containerCache) ? (this.instance.isOver || (this.instance.isOver = 1, this.instance.currentItem = e(i).clone().removeAttr("id").appendTo(this.instance.element).data("sortable-item", !0), this.instance.options._helper = this.instance.options.helper, this.instance.options.helper = function() { return n.helper[0] }, t.target = this.instance.currentItem[0], this.instance._mouseCapture(t, !0), this.instance._mouseStart(t, !0, !0), this.instance.offset.click.top = r.offset.click.top, this.instance.offset.click.left = r.offset.click.left, this.instance.offset.parent.left -= r.offset.parent.left - this.instance.offset.parent.left, this.instance.offset.parent.top -= r.offset.parent.top - this.instance.offset.parent.top, r._trigger("toSortable", t), r.dropped = this.instance.element, r.currentItem = r.element, this.instance.fromOutside = r), this.instance.currentItem && this.instance._mouseDrag(t)) : this.instance.isOver && (this.instance.isOver = 0, this.instance.cancelHelperRemoval = !0, this.instance.options.revert = !1, this.instance._trigger("out", t, this.instance._uiHash(this.instance)), this.instance._mouseStop(t, !0), this.instance.options.helper = this.instance.options._helper, this.instance.currentItem.remove(), this.instance.placeholder && this.instance.placeholder.remove(), r._trigger("fromSortable", t), r.dropped = !1) }) } }), e.ui.plugin.add("draggable", "cursor", { start: function(t, n) { var r = e("body"), i = e(this).data("draggable").options; r.css("cursor") && (i._cursor = r.css("cursor")), r.css("cursor", i.cursor) }, stop: function(t, n) { var r = e(this).data("draggable").options; r._cursor && e("body").css("cursor", r._cursor) } }), e.ui.plugin.add("draggable", "opacity", { start: function(t, n) { var r = e(n.helper), i = e(this).data("draggable").options; r.css("opacity") && (i._opacity = r.css("opacity")), r.css("opacity", i.opacity) }, stop: function(t, n) { var r = e(this).data("draggable").options; r._opacity && e(n.helper).css("opacity", r._opacity) } }), e.ui.plugin.add("draggable", "scroll", { start: function(t, n) { var r = e(this).data("draggable"); r.scrollParent[0] != document && r.scrollParent[0].tagName != "HTML" && (r.overflowOffset = r.scrollParent.offset()) }, drag: function(t, n) { var r = e(this).data("draggable"), i = r.options, s = !1; if (r.scrollParent[0] != document && r.scrollParent[0].tagName != "HTML") { if (!i.axis || i.axis != "x") r.overflowOffset.top + r.scrollParent[0].offsetHeight - t.pageY < i.scrollSensitivity ? r.scrollParent[0].scrollTop = s = r.scrollParent[0].scrollTop + i.scrollSpeed : t.pageY - r.overflowOffset.top < i.scrollSensitivity && (r.scrollParent[0].scrollTop = s = r.scrollParent[0].scrollTop - i.scrollSpeed); if (!i.axis || i.axis != "y") r.overflowOffset.left + r.scrollParent[0].offsetWidth - t.pageX < i.scrollSensitivity ? r.scrollParent[0].scrollLeft = s = r.scrollParent[0].scrollLeft + i.scrollSpeed : t.pageX - r.overflowOffset.left < i.scrollSensitivity && (r.scrollParent[0].scrollLeft = s = r.scrollParent[0].scrollLeft - i.scrollSpeed) } else { if (!i.axis || i.axis != "x") t.pageY - e(document).scrollTop() < i.scrollSensitivity ? s = e(document).scrollTop(e(document).scrollTop() - i.scrollSpeed) : e(window).height() - (t.pageY - e(document).scrollTop()) < i.scrollSensitivity && (s = e(document).scrollTop(e(document).scrollTop() + i.scrollSpeed)); if (!i.axis || i.axis != "y") t.pageX - e(document).scrollLeft() < i.scrollSensitivity ? s = e(document).scrollLeft(e(document).scrollLeft() - i.scrollSpeed) : e(window).width() - (t.pageX - e(document).scrollLeft()) < i.scrollSensitivity && (s = e(document).scrollLeft(e(document).scrollLeft() + i.scrollSpeed)) } s !== !1 && e.ui.ddmanager && !i.dropBehaviour && e.ui.ddmanager.prepareOffsets(r, t) } }), e.ui.plugin.add("draggable", "snap", { start: function(t, n) { var r = e(this).data("draggable"), i = r.options; r.snapElements = [], e(i.snap.constructor != String ? i.snap.items || ":data(draggable)" : i.snap).each(function() { var t = e(this), n = t.offset(); this != r.element[0] && r.snapElements.push({ item: this, width: t.outerWidth(), height: t.outerHeight(), top: n.top, left: n.left }) }) }, drag: function(t, n) { var r = e(this).data("draggable"), i = r.options, s = i.snapTolerance, o = n.offset.left, u = o + r.helperProportions.width, a = n.offset.top, f = a + r.helperProportions.height; for (var l = r.snapElements.length - 1; l >= 0; l--) { var c = r.snapElements[l].left, h = c + r.snapElements[l].width, p = r.snapElements[l].top, d = p + r.snapElements[l].height; if (!(c - s < o && o < h + s && p - s < a && a < d + s || c - s < o && o < h + s && p - s < f && f < d + s || c - s < u && u < h + s && p - s < a && a < d + s || c - s < u && u < h + s && p - s < f && f < d + s)) { r.snapElements[l].snapping && r.options.snap.release && r.options.snap.release.call(r.element, t, e.extend(r._uiHash(), { snapItem: r.snapElements[l].item })), r.snapElements[l].snapping = !1; continue } if (i.snapMode != "inner") { var v = Math.abs(p - f) <= s, m = Math.abs(d - a) <= s, g = Math.abs(c - u) <= s, y = Math.abs(h - o) <= s; v && (n.position.top = r._convertPositionTo("relative", { top: p - r.helperProportions.height, left: 0 }).top - r.margins.top), m && (n.position.top = r._convertPositionTo("relative", { top: d, left: 0 }).top - r.margins.top), g && (n.position.left = r._convertPositionTo("relative", { top: 0, left: c - r.helperProportions.width }).left - r.margins.left), y && (n.position.left = r._convertPositionTo("relative", { top: 0, left: h }).left - r.margins.left) } var b = v || m || g || y; if (i.snapMode != "outer") { var v = Math.abs(p - a) <= s, m = Math.abs(d - f) <= s, g = Math.abs(c - o) <= s, y = Math.abs(h - u) <= s; v && (n.position.top = r._convertPositionTo("relative", { top: p, left: 0 }).top - r.margins.top), m && (n.position.top = r._convertPositionTo("relative", { top: d - r.helperProportions.height, left: 0 }).top - r.margins.top), g && (n.position.left = r._convertPositionTo("relative", { top: 0, left: c }).left - r.margins.left), y && (n.position.left = r._convertPositionTo("relative", { top: 0, left: h - r.helperProportions.width }).left - r.margins.left) } !r.snapElements[l].snapping && (v || m || g || y || b) && r.options.snap.snap && r.options.snap.snap.call(r.element, t, e.extend(r._uiHash(), { snapItem: r.snapElements[l].item })), r.snapElements[l].snapping = v || m || g || y || b } } }), e.ui.plugin.add("draggable", "stack", { start: function(t, n) { var r = e(this).data("draggable").options, i = e.makeArray(e(r.stack)).sort(function(t, n) { return (parseInt(e(t).css("zIndex"), 10) || 0) - (parseInt(e(n).css("zIndex"), 10) || 0) }); if (!i.length) return; var s = parseInt(i[0].style.zIndex) || 0; e(i).each(function(e) { this.style.zIndex = s + e }), this[0].style.zIndex = s + i.length } }), e.ui.plugin.add("draggable", "zIndex", { start: function(t, n) { var r = e(n.helper), i = e(this).data("draggable").options; r.css("zIndex") && (i._zIndex = r.css("zIndex")), r.css("zIndex", i.zIndex) }, stop: function(t, n) { var r = e(this).data("draggable").options; r._zIndex && e(n.helper).css("zIndex", r._zIndex) } }) } (jQuery), function(e, t) { e.widget("ui.droppable", { version: "1.9.0", widgetEventPrefix: "drop", options: { accept: "*", activeClass: !1, addClasses: !0, greedy: !1, hoverClass: !1, scope: "default", tolerance: "intersect" }, _create: function() { var t = this.options, n = t.accept; this.isover = 0, this.isout = 1, this.accept = e.isFunction(n) ? n : function(e) { return e.is(n) }, this.proportions = { width: this.element[0].offsetWidth, height: this.element[0].offsetHeight }, e.ui.ddmanager.droppables[t.scope] = e.ui.ddmanager.droppables[t.scope] || [], e.ui.ddmanager.droppables[t.scope].push(this), t.addClasses && this.element.addClass("ui-droppable") }, _destroy: function() { var t = e.ui.ddmanager.droppables[this.options.scope]; for (var n = 0; n < t.length; n++) t[n] == this && t.splice(n, 1); this.element.removeClass("ui-droppable ui-droppable-disabled") }, _setOption: function(t, n) { t == "accept" && (this.accept = e.isFunction(n) ? n : function(e) { return e.is(n) }), e.Widget.prototype._setOption.apply(this, arguments) }, _activate: function(t) { var n = e.ui.ddmanager.current; this.options.activeClass && this.element.addClass(this.options.activeClass), n && this._trigger("activate", t, this.ui(n)) }, _deactivate: function(t) { var n = e.ui.ddmanager.current; this.options.activeClass && this.element.removeClass(this.options.activeClass), n && this._trigger("deactivate", t, this.ui(n)) }, _over: function(t) { var n = e.ui.ddmanager.current; if (!n || (n.currentItem || n.element)[0] == this.element[0]) return; this.accept.call(this.element[0], n.currentItem || n.element) && (this.options.hoverClass && this.element.addClass(this.options.hoverClass), this._trigger("over", t, this.ui(n))) }, _out: function(t) { var n = e.ui.ddmanager.current; if (!n || (n.currentItem || n.element)[0] == this.element[0]) return; this.accept.call(this.element[0], n.currentItem || n.element) && (this.options.hoverClass && this.element.removeClass(this.options.hoverClass), this._trigger("out", t, this.ui(n))) }, _drop: function(t, n) { var r = n || e.ui.ddmanager.current; if (!r || (r.currentItem || r.element)[0] == this.element[0]) return !1; var i = !1; return this.element.find(":data(droppable)").not(".ui-draggable-dragging").each(function() { var t = e.data(this, "droppable"); if (t.options.greedy && !t.options.disabled && t.options.scope == r.options.scope && t.accept.call(t.element[0], r.currentItem || r.element) && e.ui.intersect(r, e.extend(t, { offset: t.element.offset() }), t.options.tolerance)) return i = !0, !1 }), i ? !1 : this.accept.call(this.element[0], r.currentItem || r.element) ? (this.options.activeClass && this.element.removeClass(this.options.activeClass), this.options.hoverClass && this.element.removeClass(this.options.hoverClass), this._trigger("drop", t, this.ui(r)), this.element) : !1 }, ui: function(e) { return { draggable: e.currentItem || e.element, helper: e.helper, position: e.position, offset: e.positionAbs} } }), e.ui.intersect = function(t, n, r) { if (!n.offset) return !1; var i = (t.positionAbs || t.position.absolute).left, s = i + t.helperProportions.width, o = (t.positionAbs || t.position.absolute).top, u = o + t.helperProportions.height, a = n.offset.left, f = a + n.proportions.width, l = n.offset.top, c = l + n.proportions.height; switch (r) { case "fit": return a <= i && s <= f && l <= o && u <= c; case "intersect": return a < i + t.helperProportions.width / 2 && s - t.helperProportions.width / 2 < f && l < o + t.helperProportions.height / 2 && u - t.helperProportions.height / 2 < c; case "pointer": var h = (t.positionAbs || t.position.absolute).left + (t.clickOffset || t.offset.click).left, p = (t.positionAbs || t.position.absolute).top + (t.clickOffset || t.offset.click).top, d = e.ui.isOver(p, h, l, a, n.proportions.height, n.proportions.width); return d; case "touch": return (o >= l && o <= c || u >= l && u <= c || o < l && u > c) && (i >= a && i <= f || s >= a && s <= f || i < a && s > f); default: return !1 } }, e.ui.ddmanager = { current: null, droppables: { "default": [] }, prepareOffsets: function(t, n) { var r = e.ui.ddmanager.droppables[t.options.scope] || [], i = n ? n.type : null, s = (t.currentItem || t.element).find(":data(droppable)").andSelf(); e: for (var o = 0; o < r.length; o++) { if (r[o].options.disabled || t && !r[o].accept.call(r[o].element[0], t.currentItem || t.element)) continue; for (var u = 0; u < s.length; u++) if (s[u] == r[o].element[0]) { r[o].proportions.height = 0; continue e } r[o].visible = r[o].element.css("display") != "none"; if (!r[o].visible) continue; i == "mousedown" && r[o]._activate.call(r[o], n), r[o].offset = r[o].element.offset(), r[o].proportions = { width: r[o].element[0].offsetWidth, height: r[o].element[0].offsetHeight} } }, drop: function(t, n) { var r = !1; return e.each(e.ui.ddmanager.droppables[t.options.scope] || [], function() { if (!this.options) return; !this.options.disabled && this.visible && e.ui.intersect(t, this, this.options.tolerance) && (r = this._drop.call(this, n) || r), !this.options.disabled && this.visible && this.accept.call(this.element[0], t.currentItem || t.element) && (this.isout = 1, this.isover = 0, this._deactivate.call(this, n)) }), r }, dragStart: function(t, n) { t.element.parentsUntil("body").bind("scroll.droppable", function() { t.options.refreshPositions || e.ui.ddmanager.prepareOffsets(t, n) }) }, drag: function(t, n) { t.options.refreshPositions && e.ui.ddmanager.prepareOffsets(t, n), e.each(e.ui.ddmanager.droppables[t.options.scope] || [], function() { if (this.options.disabled || this.greedyChild || !this.visible) return; var r = e.ui.intersect(t, this, this.options.tolerance), i = !r && this.isover == 1 ? "isout" : r && this.isover == 0 ? "isover" : null; if (!i) return; var s; if (this.options.greedy) { var o = this.options.scope, u = this.element.parents(":data(droppable)").filter(function() { return e.data(this, "droppable").options.scope === o }); u.length && (s = e.data(u[0], "droppable"), s.greedyChild = i == "isover" ? 1 : 0) } s && i == "isover" && (s.isover = 0, s.isout = 1, s._out.call(s, n)), this[i] = 1, this[i == "isout" ? "isover" : "isout"] = 0, this[i == "isover" ? "_over" : "_out"].call(this, n), s && i == "isout" && (s.isout = 0, s.isover = 1, s._over.call(s, n)) }) }, dragStop: function(t, n) { t.element.parentsUntil("body").unbind("scroll.droppable"), t.options.refreshPositions || e.ui.ddmanager.prepareOffsets(t, n) } } } (jQuery), function(e, t) { e.widget("ui.resizable", e.ui.mouse, { version: "1.9.0", widgetEventPrefix: "resize", options: { alsoResize: !1, animate: !1, animateDuration: "slow", animateEasing: "swing", aspectRatio: !1, autoHide: !1, containment: !1, ghost: !1, grid: !1, handles: "e,s,se", helper: !1, maxHeight: null, maxWidth: null, minHeight: 10, minWidth: 10, zIndex: 1e3 }, _create: function() { var t = this, n = this.options; this.element.addClass("ui-resizable"), e.extend(this, { _aspectRatio: !!n.aspectRatio, aspectRatio: n.aspectRatio, originalElement: this.element, _proportionallyResizeElements: [], _helper: n.helper || n.ghost || n.animate ? n.helper || "ui-resizable-helper" : null }), this.element[0].nodeName.match(/canvas|textarea|input|select|button|img/i) && (this.element.wrap(e('
').css({ position: this.element.css("position"), width: this.element.outerWidth(), height: this.element.outerHeight(), top: this.element.css("top"), left: this.element.css("left") })), this.element = this.element.parent().data("resizable", this.element.data("resizable")), this.elementIsWrapper = !0, this.element.css({ marginLeft: this.originalElement.css("marginLeft"), marginTop: this.originalElement.css("marginTop"), marginRight: this.originalElement.css("marginRight"), marginBottom: this.originalElement.css("marginBottom") }), this.originalElement.css({ marginLeft: 0, marginTop: 0, marginRight: 0, marginBottom: 0 }), this.originalResizeStyle = this.originalElement.css("resize"), this.originalElement.css("resize", "none"), this._proportionallyResizeElements.push(this.originalElement.css({ position: "static", zoom: 1, display: "block" })), this.originalElement.css({ margin: this.originalElement.css("margin") }), this._proportionallyResize()), this.handles = n.handles || (e(".ui-resizable-handle", this.element).length ? { n: ".ui-resizable-n", e: ".ui-resizable-e", s: ".ui-resizable-s", w: ".ui-resizable-w", se: ".ui-resizable-se", sw: ".ui-resizable-sw", ne: ".ui-resizable-ne", nw: ".ui-resizable-nw"} : "e,s,se"); if (this.handles.constructor == String) { this.handles == "all" && (this.handles = "n,e,s,w,se,sw,ne,nw"); var r = this.handles.split(","); this.handles = {}; for (var i = 0; i < r.length; i++) { var s = e.trim(r[i]), o = "ui-resizable-" + s, u = e('
'); u.css({ zIndex: n.zIndex }), "se" == s && u.addClass("ui-icon ui-icon-gripsmall-diagonal-se"), this.handles[s] = ".ui-resizable-" + s, this.element.append(u) } } this._renderAxis = function(t) { t = t || this.element; for (var n in this.handles) { this.handles[n].constructor == String && (this.handles[n] = e(this.handles[n], this.element).show()); if (this.elementIsWrapper && this.originalElement[0].nodeName.match(/textarea|input|select|button/i)) { var r = e(this.handles[n], this.element), i = 0; i = /sw|ne|nw|se|n|s/.test(n) ? r.outerHeight() : r.outerWidth(); var s = ["padding", /ne|nw|n/.test(n) ? "Top" : /se|sw|s/.test(n) ? "Bottom" : /^e$/.test(n) ? "Right" : "Left"].join(""); t.css(s, i), this._proportionallyResize() } if (!e(this.handles[n]).length) continue } }, this._renderAxis(this.element), this._handles = e(".ui-resizable-handle", this.element).disableSelection(), this._handles.mouseover(function() { if (!t.resizing) { if (this.className) var e = this.className.match(/ui-resizable-(se|sw|ne|nw|n|e|s|w)/i); t.axis = e && e[1] ? e[1] : "se" } }), n.autoHide && (this._handles.hide(), e(this.element).addClass("ui-resizable-autohide").mouseenter(function() { if (n.disabled) return; e(this).removeClass("ui-resizable-autohide"), t._handles.show() }).mouseleave(function() { if (n.disabled) return; t.resizing || (e(this).addClass("ui-resizable-autohide"), t._handles.hide()) })), this._mouseInit() }, _destroy: function() { this._mouseDestroy(); var t = function(t) { e(t).removeClass("ui-resizable ui-resizable-disabled ui-resizable-resizing").removeData("resizable").removeData("ui-resizable").unbind(".resizable").find(".ui-resizable-handle").remove() }; if (this.elementIsWrapper) { t(this.element); var n = this.element; n.after(this.originalElement.css({ position: n.css("position"), width: n.outerWidth(), height: n.outerHeight(), top: n.css("top"), left: n.css("left") })).remove() } return this.originalElement.css("resize", this.originalResizeStyle), t(this.originalElement), this }, _mouseCapture: function(t) { var n = !1; for (var r in this.handles) e(this.handles[r])[0] == t.target && (n = !0); return !this.options.disabled && n }, _mouseStart: function(t) { var r = this.options, i = this.element.position(), s = this.element; this.resizing = !0, this.documentScroll = { top: e(document).scrollTop(), left: e(document).scrollLeft() }, (s.is(".ui-draggable") || /absolute/.test(s.css("position"))) && s.css({ position: "absolute", top: i.top, left: i.left }), this._renderProxy(); var o = n(this.helper.css("left")), u = n(this.helper.css("top")); r.containment && (o += e(r.containment).scrollLeft() || 0, u += e(r.containment).scrollTop() || 0), this.offset = this.helper.offset(), this.position = { left: o, top: u }, this.size = this._helper ? { width: s.outerWidth(), height: s.outerHeight()} : { width: s.width(), height: s.height() }, this.originalSize = this._helper ? { width: s.outerWidth(), height: s.outerHeight()} : { width: s.width(), height: s.height() }, this.originalPosition = { left: o, top: u }, this.sizeDiff = { width: s.outerWidth() - s.width(), height: s.outerHeight() - s.height() }, this.originalMousePosition = { left: t.pageX, top: t.pageY }, this.aspectRatio = typeof r.aspectRatio == "number" ? r.aspectRatio : this.originalSize.width / this.originalSize.height || 1; var a = e(".ui-resizable-" + this.axis).css("cursor"); return e("body").css("cursor", a == "auto" ? this.axis + "-resize" : a), s.addClass("ui-resizable-resizing"), this._propagate("start", t), !0 }, _mouseDrag: function(e) { var t = this.helper, n = this.options, r = {}, i = this, s = this.originalMousePosition, o = this.axis, u = e.pageX - s.left || 0, a = e.pageY - s.top || 0, f = this._change[o]; if (!f) return !1; var l = f.apply(this, [e, u, a]); this._updateVirtualBoundaries(e.shiftKey); if (this._aspectRatio || e.shiftKey) l = this._updateRatio(l, e); return l = this._respectSize(l, e), this._propagate("resize", e), t.css({ top: this.position.top + "px", left: this.position.left + "px", width: this.size.width + "px", height: this.size.height + "px" }), !this._helper && this._proportionallyResizeElements.length && this._proportionallyResize(), this._updateCache(l), this._trigger("resize", e, this.ui()), !1 }, _mouseStop: function(t) { this.resizing = !1; var n = this.options, r = this; if (this._helper) { var i = this._proportionallyResizeElements, s = i.length && /textarea/i.test(i[0].nodeName), o = s && e.ui.hasScroll(i[0], "left") ? 0 : r.sizeDiff.height, u = s ? 0 : r.sizeDiff.width, a = { width: r.helper.width() - u, height: r.helper.height() - o }, f = parseInt(r.element.css("left"), 10) + (r.position.left - r.originalPosition.left) || null, l = parseInt(r.element.css("top"), 10) + (r.position.top - r.originalPosition.top) || null; n.animate || this.element.css(e.extend(a, { top: l, left: f })), r.helper.height(r.size.height), r.helper.width(r.size.width), this._helper && !n.animate && this._proportionallyResize() } return e("body").css("cursor", "auto"), this.element.removeClass("ui-resizable-resizing"), this._propagate("stop", t), this._helper && this.helper.remove(), !1 }, _updateVirtualBoundaries: function(e) { var t = this.options, n, i, s, o, u; u = { minWidth: r(t.minWidth) ? t.minWidth : 0, maxWidth: r(t.maxWidth) ? t.maxWidth : Infinity, minHeight: r(t.minHeight) ? t.minHeight : 0, maxHeight: r(t.maxHeight) ? t.maxHeight : Infinity }; if (this._aspectRatio || e) n = u.minHeight * this.aspectRatio, s = u.minWidth / this.aspectRatio, i = u.maxHeight * this.aspectRatio, o = u.maxWidth / this.aspectRatio, n > u.minWidth && (u.minWidth = n), s > u.minHeight && (u.minHeight = s), i < u.maxWidth && (u.maxWidth = i), o < u.maxHeight && (u.maxHeight = o); this._vBoundaries = u }, _updateCache: function(e) { var t = this.options; this.offset = this.helper.offset(), r(e.left) && (this.position.left = e.left), r(e.top) && (this.position.top = e.top), r(e.height) && (this.size.height = e.height), r(e.width) && (this.size.width = e.width) }, _updateRatio: function(e, t) { var n = this.options, i = this.position, s = this.size, o = this.axis; return r(e.height) ? e.width = e.height * this.aspectRatio : r(e.width) && (e.height = e.width / this.aspectRatio), o == "sw" && (e.left = i.left + (s.width - e.width), e.top = null), o == "nw" && (e.top = i.top + (s.height - e.height), e.left = i.left + (s.width - e.width)), e }, _respectSize: function(e, t) { var n = this.helper, i = this._vBoundaries, s = this._aspectRatio || t.shiftKey, o = this.axis, u = r(e.width) && i.maxWidth && i.maxWidth < e.width, a = r(e.height) && i.maxHeight && i.maxHeight < e.height, f = r(e.width) && i.minWidth && i.minWidth > e.width, l = r(e.height) && i.minHeight && i.minHeight > e.height; f && (e.width = i.minWidth), l && (e.height = i.minHeight), u && (e.width = i.maxWidth), a && (e.height = i.maxHeight); var c = this.originalPosition.left + this.originalSize.width, h = this.position.top + this.size.height, p = /sw|nw|w/.test(o), d = /nw|ne|n/.test(o); f && p && (e.left = c - i.minWidth), u && p && (e.left = c - i.maxWidth), l && d && (e.top = h - i.minHeight), a && d && (e.top = h - i.maxHeight); var v = !e.width && !e.height; return v && !e.left && e.top ? e.top = null : v && !e.top && e.left && (e.left = null), e }, _proportionallyResize: function() { var t = this.options; if (!this._proportionallyResizeElements.length) return; var n = this.helper || this.element; for (var r = 0; r < this._proportionallyResizeElements.length; r++) { var i = this._proportionallyResizeElements[r]; if (!this.borderDif) { var s = [i.css("borderTopWidth"), i.css("borderRightWidth"), i.css("borderBottomWidth"), i.css("borderLeftWidth")], o = [i.css("paddingTop"), i.css("paddingRight"), i.css("paddingBottom"), i.css("paddingLeft")]; this.borderDif = e.map(s, function(e, t) { var n = parseInt(e, 10) || 0, r = parseInt(o[t], 10) || 0; return n + r }) } i.css({ height: n.height() - this.borderDif[0] - this.borderDif[2] || 0, width: n.width() - this.borderDif[1] - this.borderDif[3] || 0 }) } }, _renderProxy: function() { var t = this.element, n = this.options; this.elementOffset = t.offset(); if (this._helper) { this.helper = this.helper || e('
'); var r = e.browser.msie && e.browser.version < 7, i = r ? 1 : 0, s = r ? 2 : -1; this.helper.addClass(this._helper).css({ width: this.element.outerWidth() + s, height: this.element.outerHeight() + s, position: "absolute", left: this.elementOffset.left - i + "px", top: this.elementOffset.top - i + "px", zIndex: ++n.zIndex }), this.helper.appendTo("body").disableSelection() } else this.helper = this.element }, _change: { e: function(e, t, n) { return { width: this.originalSize.width + t} }, w: function(e, t, n) { var r = this.options, i = this.originalSize, s = this.originalPosition; return { left: s.left + t, width: i.width - t} }, n: function(e, t, n) { var r = this.options, i = this.originalSize, s = this.originalPosition; return { top: s.top + n, height: i.height - n} }, s: function(e, t, n) { return { height: this.originalSize.height + n} }, se: function(t, n, r) { return e.extend(this._change.s.apply(this, arguments), this._change.e.apply(this, [t, n, r])) }, sw: function(t, n, r) { return e.extend(this._change.s.apply(this, arguments), this._change.w.apply(this, [t, n, r])) }, ne: function(t, n, r) { return e.extend(this._change.n.apply(this, arguments), this._change.e.apply(this, [t, n, r])) }, nw: function(t, n, r) { return e.extend(this._change.n.apply(this, arguments), this._change.w.apply(this, [t, n, r])) } }, _propagate: function(t, n) { e.ui.plugin.call(this, t, [n, this.ui()]), t != "resize" && this._trigger(t, n, this.ui()) }, plugins: {}, ui: function() { return { originalElement: this.originalElement, element: this.element, helper: this.helper, position: this.position, size: this.size, originalSize: this.originalSize, originalPosition: this.originalPosition} } }), e.ui.plugin.add("resizable", "alsoResize", { start: function(t, n) { var r = e(this).data("resizable"), i = r.options, s = function(t) { e(t).each(function() { var t = e(this); t.data("resizable-alsoresize", { width: parseInt(t.width(), 10), height: parseInt(t.height(), 10), left: parseInt(t.css("left"), 10), top: parseInt(t.css("top"), 10) }) }) }; typeof i.alsoResize == "object" && !i.alsoResize.parentNode ? i.alsoResize.length ? (i.alsoResize = i.alsoResize[0], s(i.alsoResize)) : e.each(i.alsoResize, function(e) { s(e) }) : s(i.alsoResize) }, resize: function(t, n) { var r = e(this).data("resizable"), i = r.options, s = r.originalSize, o = r.originalPosition, u = { height: r.size.height - s.height || 0, width: r.size.width - s.width || 0, top: r.position.top - o.top || 0, left: r.position.left - o.left || 0 }, a = function(t, r) { e(t).each(function() { var t = e(this), i = e(this).data("resizable-alsoresize"), s = {}, o = r && r.length ? r : t.parents(n.originalElement[0]).length ? ["width", "height"] : ["width", "height", "top", "left"]; e.each(o, function(e, t) { var n = (i[t] || 0) + (u[t] || 0); n && n >= 0 && (s[t] = n || null) }), t.css(s) }) }; typeof i.alsoResize == "object" && !i.alsoResize.nodeType ? e.each(i.alsoResize, function(e, t) { a(e, t) }) : a(i.alsoResize) }, stop: function(t, n) { e(this).removeData("resizable-alsoresize") } }), e.ui.plugin.add("resizable", "animate", { stop: function(t, n) { var r = e(this).data("resizable"), i = r.options, s = r._proportionallyResizeElements, o = s.length && /textarea/i.test(s[0].nodeName), u = o && e.ui.hasScroll(s[0], "left") ? 0 : r.sizeDiff.height, a = o ? 0 : r.sizeDiff.width, f = { width: r.size.width - a, height: r.size.height - u }, l = parseInt(r.element.css("left"), 10) + (r.position.left - r.originalPosition.left) || null, c = parseInt(r.element.css("top"), 10) + (r.position.top - r.originalPosition.top) || null; r.element.animate(e.extend(f, c && l ? { top: c, left: l} : {}), { duration: i.animateDuration, easing: i.animateEasing, step: function() { var n = { width: parseInt(r.element.css("width"), 10), height: parseInt(r.element.css("height"), 10), top: parseInt(r.element.css("top"), 10), left: parseInt(r.element.css("left"), 10) }; s && s.length && e(s[0]).css({ width: n.width, height: n.height }), r._updateCache(n), r._propagate("resize", t) } }) } }), e.ui.plugin.add("resizable", "containment", { start: function(t, r) { var i = e(this).data("resizable"), s = i.options, o = i.element, u = s.containment, a = u instanceof e ? u.get(0) : /parent/.test(u) ? o.parent().get(0) : u; if (!a) return; i.containerElement = e(a); if (/document/.test(u) || u == document) i.containerOffset = { left: 0, top: 0 }, i.containerPosition = { left: 0, top: 0 }, i.parentData = { element: e(document), left: 0, top: 0, width: e(document).width(), height: e(document).height() || document.body.parentNode.scrollHeight }; else { var f = e(a), l = []; e(["Top", "Right", "Left", "Bottom"]).each(function(e, t) { l[e] = n(f.css("padding" + t)) }), i.containerOffset = f.offset(), i.containerPosition = f.position(), i.containerSize = { height: f.innerHeight() - l[3], width: f.innerWidth() - l[1] }; var c = i.containerOffset, h = i.containerSize.height, p = i.containerSize.width, d = e.ui.hasScroll(a, "left") ? a.scrollWidth : p, v = e.ui.hasScroll(a) ? a.scrollHeight : h; i.parentData = { element: a, left: c.left, top: c.top, width: d, height: v} } }, resize: function(t, n) { var r = e(this).data("resizable"), i = r.options, s = r.containerSize, o = r.containerOffset, u = r.size, a = r.position, f = r._aspectRatio || t.shiftKey, l = { top: 0, left: 0 }, c = r.containerElement; c[0] != document && /static/.test(c.css("position")) && (l = o), a.left < (r._helper ? o.left : 0) && (r.size.width = r.size.width + (r._helper ? r.position.left - o.left : r.position.left - l.left), f && (r.size.height = r.size.width / r.aspectRatio), r.position.left = i.helper ? o.left : 0), a.top < (r._helper ? o.top : 0) && (r.size.height = r.size.height + (r._helper ? r.position.top - o.top : r.position.top), f && (r.size.width = r.size.height * r.aspectRatio), r.position.top = r._helper ? o.top : 0), r.offset.left = r.parentData.left + r.position.left, r.offset.top = r.parentData.top + r.position.top; var h = Math.abs((r._helper ? r.offset.left - l.left : r.offset.left - l.left) + r.sizeDiff.width), p = Math.abs((r._helper ? r.offset.top - l.top : r.offset.top - o.top) + r.sizeDiff.height), d = r.containerElement.get(0) == r.element.parent().get(0), v = /relative|absolute/.test(r.containerElement.css("position")); d && v && (h -= r.parentData.left), h + r.size.width >= r.parentData.width && (r.size.width = r.parentData.width - h, f && (r.size.height = r.size.width / r.aspectRatio)), p + r.size.height >= r.parentData.height && (r.size.height = r.parentData.height - p, f && (r.size.width = r.size.height * r.aspectRatio)) }, stop: function(t, n) { var r = e(this).data("resizable"), i = r.options, s = r.position, o = r.containerOffset, u = r.containerPosition, a = r.containerElement, f = e(r.helper), l = f.offset(), c = f.outerWidth() - r.sizeDiff.width, h = f.outerHeight() - r.sizeDiff.height; r._helper && !i.animate && /relative/.test(a.css("position")) && e(this).css({ left: l.left - u.left - o.left, width: c, height: h }), r._helper && !i.animate && /static/.test(a.css("position")) && e(this).css({ left: l.left - u.left - o.left, width: c, height: h }) } }), e.ui.plugin.add("resizable", "ghost", { start: function(t, n) { var r = e(this).data("resizable"), i = r.options, s = r.size; r.ghost = r.originalElement.clone(), r.ghost.css({ opacity: .25, display: "block", position: "relative", height: s.height, width: s.width, margin: 0, left: 0, top: 0 }).addClass("ui-resizable-ghost").addClass(typeof i.ghost == "string" ? i.ghost : ""), r.ghost.appendTo(r.helper) }, resize: function(t, n) { var r = e(this).data("resizable"), i = r.options; r.ghost && r.ghost.css({ position: "relative", height: r.size.height, width: r.size.width }) }, stop: function(t, n) { var r = e(this).data("resizable"), i = r.options; r.ghost && r.helper && r.helper.get(0).removeChild(r.ghost.get(0)) } }), e.ui.plugin.add("resizable", "grid", { resize: function(t, n) { var r = e(this).data("resizable"), i = r.options, s = r.size, o = r.originalSize, u = r.originalPosition, a = r.axis, f = i._aspectRatio || t.shiftKey; i.grid = typeof i.grid == "number" ? [i.grid, i.grid] : i.grid; var l = Math.round((s.width - o.width) / (i.grid[0] || 1)) * (i.grid[0] || 1), c = Math.round((s.height - o.height) / (i.grid[1] || 1)) * (i.grid[1] || 1); /^(se|s|e)$/.test(a) ? (r.size.width = o.width + l, r.size.height = o.height + c) : /^(ne)$/.test(a) ? (r.size.width = o.width + l, r.size.height = o.height + c, r.position.top = u.top - c) : /^(sw)$/.test(a) ? (r.size.width = o.width + l, r.size.height = o.height + c, r.position.left = u.left - l) : (r.size.width = o.width + l, r.size.height = o.height + c, r.position.top = u.top - c, r.position.left = u.left - l) } }); var n = function(e) { return parseInt(e, 10) || 0 }, r = function(e) { return !isNaN(parseInt(e, 10)) } } (jQuery), function(e, t) { e.widget("ui.selectable", e.ui.mouse, { version: "1.9.0", options: { appendTo: "body", autoRefresh: !0, distance: 0, filter: "*", tolerance: "touch" }, _create: function() { var t = this; this.element.addClass("ui-selectable"), this.dragged = !1; var n; this.refresh = function() { n = e(t.options.filter, t.element[0]), n.addClass("ui-selectee"), n.each(function() { var t = e(this), n = t.offset(); e.data(this, "selectable-item", { element: this, $element: t, left: n.left, top: n.top, right: n.left + t.outerWidth(), bottom: n.top + t.outerHeight(), startselected: !1, selected: t.hasClass("ui-selected"), selecting: t.hasClass("ui-selecting"), unselecting: t.hasClass("ui-unselecting") }) }) }, this.refresh(), this.selectees = n.addClass("ui-selectee"), this._mouseInit(), this.helper = e("
") }, _destroy: function() { this.selectees.removeClass("ui-selectee").removeData("selectable-item"), this.element.removeClass("ui-selectable ui-selectable-disabled"), this._mouseDestroy() }, _mouseStart: function(t) { var n = this; this.opos = [t.pageX, t.pageY]; if (this.options.disabled) return; var r = this.options; this.selectees = e(r.filter, this.element[0]), this._trigger("start", t), e(r.appendTo).append(this.helper), this.helper.css({ left: t.clientX, top: t.clientY, width: 0, height: 0 }), r.autoRefresh && this.refresh(), this.selectees.filter(".ui-selected").each(function() { var r = e.data(this, "selectable-item"); r.startselected = !0, !t.metaKey && !t.ctrlKey && (r.$element.removeClass("ui-selected"), r.selected = !1, r.$element.addClass("ui-unselecting"), r.unselecting = !0, n._trigger("unselecting", t, { unselecting: r.element })) }), e(t.target).parents().andSelf().each(function() { var r = e.data(this, "selectable-item"); if (r) { var i = !t.metaKey && !t.ctrlKey || !r.$element.hasClass("ui-selected"); return r.$element.removeClass(i ? "ui-unselecting" : "ui-selected").addClass(i ? "ui-selecting" : "ui-unselecting"), r.unselecting = !i, r.selecting = i, r.selected = i, i ? n._trigger("selecting", t, { selecting: r.element }) : n._trigger("unselecting", t, { unselecting: r.element }), !1 } }) }, _mouseDrag: function(t) { var n = this; this.dragged = !0; if (this.options.disabled) return; var r = this.options, i = this.opos[0], s = this.opos[1], o = t.pageX, u = t.pageY; if (i > o) { var a = o; o = i, i = a } if (s > u) { var a = u; u = s, s = a } return this.helper.css({ left: i, top: s, width: o - i, height: u - s }), this.selectees.each(function() { var a = e.data(this, "selectable-item"); if (!a || a.element == n.element[0]) return; var f = !1; r.tolerance == "touch" ? f = !(a.left > o || a.right < i || a.top > u || a.bottom < s) : r.tolerance == "fit" && (f = a.left > i && a.right < o && a.top > s && a.bottom < u), f ? (a.selected && (a.$element.removeClass("ui-selected"), a.selected = !1), a.unselecting && (a.$element.removeClass("ui-unselecting"), a.unselecting = !1), a.selecting || (a.$element.addClass("ui-selecting"), a.selecting = !0, n._trigger("selecting", t, { selecting: a.element }))) : (a.selecting && ((t.metaKey || t.ctrlKey) && a.startselected ? (a.$element.removeClass("ui-selecting"), a.selecting = !1, a.$element.addClass("ui-selected"), a.selected = !0) : (a.$element.removeClass("ui-selecting"), a.selecting = !1, a.startselected && (a.$element.addClass("ui-unselecting"), a.unselecting = !0), n._trigger("unselecting", t, { unselecting: a.element }))), a.selected && !t.metaKey && !t.ctrlKey && !a.startselected && (a.$element.removeClass("ui-selected"), a.selected = !1, a.$element.addClass("ui-unselecting"), a.unselecting = !0, n._trigger("unselecting", t, { unselecting: a.element }))) }), !1 }, _mouseStop: function(t) { var n = this; this.dragged = !1; var r = this.options; return e(".ui-unselecting", this.element[0]).each(function() { var r = e.data(this, "selectable-item"); r.$element.removeClass("ui-unselecting"), r.unselecting = !1, r.startselected = !1, n._trigger("unselected", t, { unselected: r.element }) }), e(".ui-selecting", this.element[0]).each(function() { var r = e.data(this, "selectable-item"); r.$element.removeClass("ui-selecting").addClass("ui-selected"), r.selecting = !1, r.selected = !0, r.startselected = !0, n._trigger("selected", t, { selected: r.element }) }), this._trigger("stop", t), this.helper.remove(), !1 } }) } (jQuery), function(e, t) { e.widget("ui.sortable", e.ui.mouse, { version: "1.9.0", widgetEventPrefix: "sort", ready: !1, options: { appendTo: "parent", axis: !1, connectWith: !1, containment: !1, cursor: "auto", cursorAt: !1, dropOnEmpty: !0, forcePlaceholderSize: !1, forceHelperSize: !1, grid: !1, handle: !1, helper: "original", items: "> *", opacity: !1, placeholder: !1, revert: !1, scroll: !0, scrollSensitivity: 20, scrollSpeed: 20, scope: "default", tolerance: "intersect", zIndex: 1e3 }, _create: function() { var e = this.options; this.containerCache = {}, this.element.addClass("ui-sortable"), this.refresh(), this.floating = this.items.length ? e.axis === "x" || /left|right/.test(this.items[0].item.css("float")) || /inline|table-cell/.test(this.items[0].item.css("display")) : !1, this.offset = this.element.offset(), this._mouseInit(), this.ready = !0 }, _destroy: function() { this.element.removeClass("ui-sortable ui-sortable-disabled"), this._mouseDestroy(); for (var e = this.items.length - 1; e >= 0; e--) this.items[e].item.removeData(this.widgetName + "-item"); return this }, _setOption: function(t, n) { t === "disabled" ? (this.options[t] = n, this.widget().toggleClass("ui-sortable-disabled", !!n)) : e.Widget.prototype._setOption.apply(this, arguments) }, _mouseCapture: function(t, n) { var r = this; if (this.reverting) return !1; if (this.options.disabled || this.options.type == "static") return !1; this._refreshItems(t); var i = null, s = e(t.target).parents().each(function() { if (e.data(this, r.widgetName + "-item") == r) return i = e(this), !1 }); e.data(t.target, r.widgetName + "-item") == r && (i = e(t.target)); if (!i) return !1; if (this.options.handle && !n) { var o = !1; e(this.options.handle, i).find("*").andSelf().each(function() { this == t.target && (o = !0) }); if (!o) return !1 } return this.currentItem = i, this._removeCurrentsFromItems(), !0 }, _mouseStart: function(t, n, r) { var i = this.options; this.currentContainer = this, this.refreshPositions(), this.helper = this._createHelper(t), this._cacheHelperProportions(), this._cacheMargins(), this.scrollParent = this.helper.scrollParent(), this.offset = this.currentItem.offset(), this.offset = { top: this.offset.top - this.margins.top, left: this.offset.left - this.margins.left }, e.extend(this.offset, { click: { left: t.pageX - this.offset.left, top: t.pageY - this.offset.top }, parent: this._getParentOffset(), relative: this._getRelativeOffset() }), this.helper.css("position", "absolute"), this.cssPosition = this.helper.css("position"), this.originalPosition = this._generatePosition(t), this.originalPageX = t.pageX, this.originalPageY = t.pageY, i.cursorAt && this._adjustOffsetFromHelper(i.cursorAt), this.domPosition = { prev: this.currentItem.prev()[0], parent: this.currentItem.parent()[0] }, this.helper[0] != this.currentItem[0] && this.currentItem.hide(), this._createPlaceholder(), i.containment && this._setContainment(), i.cursor && (e("body").css("cursor") && (this._storedCursor = e("body").css("cursor")), e("body").css("cursor", i.cursor)), i.opacity && (this.helper.css("opacity") && (this._storedOpacity = this.helper.css("opacity")), this.helper.css("opacity", i.opacity)), i.zIndex && (this.helper.css("zIndex") && (this._storedZIndex = this.helper.css("zIndex")), this.helper.css("zIndex", i.zIndex)), this.scrollParent[0] != document && this.scrollParent[0].tagName != "HTML" && (this.overflowOffset = this.scrollParent.offset()), this._trigger("start", t, this._uiHash()), this._preserveHelperProportions || this._cacheHelperProportions(); if (!r) for (var s = this.containers.length - 1; s >= 0; s--) this.containers[s]._trigger("activate", t, this._uiHash(this)); return e.ui.ddmanager && (e.ui.ddmanager.current = this), e.ui.ddmanager && !i.dropBehaviour && e.ui.ddmanager.prepareOffsets(this, t), this.dragging = !0, this.helper.addClass("ui-sortable-helper"), this._mouseDrag(t), !0 }, _mouseDrag: function(t) { this.position = this._generatePosition(t), this.positionAbs = this._convertPositionTo("absolute"), this.lastPositionAbs || (this.lastPositionAbs = this.positionAbs); if (this.options.scroll) { var n = this.options, r = !1; this.scrollParent[0] != document && this.scrollParent[0].tagName != "HTML" ? (this.overflowOffset.top + this.scrollParent[0].offsetHeight - t.pageY < n.scrollSensitivity ? this.scrollParent[0].scrollTop = r = this.scrollParent[0].scrollTop + n.scrollSpeed : t.pageY - this.overflowOffset.top < n.scrollSensitivity && (this.scrollParent[0].scrollTop = r = this.scrollParent[0].scrollTop - n.scrollSpeed), this.overflowOffset.left + this.scrollParent[0].offsetWidth - t.pageX < n.scrollSensitivity ? this.scrollParent[0].scrollLeft = r = this.scrollParent[0].scrollLeft + n.scrollSpeed : t.pageX - this.overflowOffset.left < n.scrollSensitivity && (this.scrollParent[0].scrollLeft = r = this.scrollParent[0].scrollLeft - n.scrollSpeed)) : (t.pageY - e(document).scrollTop() < n.scrollSensitivity ? r = e(document).scrollTop(e(document).scrollTop() - n.scrollSpeed) : e(window).height() - (t.pageY - e(document).scrollTop()) < n.scrollSensitivity && (r = e(document).scrollTop(e(document).scrollTop() + n.scrollSpeed)), t.pageX - e(document).scrollLeft() < n.scrollSensitivity ? r = e(document).scrollLeft(e(document).scrollLeft() - n.scrollSpeed) : e(window).width() - (t.pageX - e(document).scrollLeft()) < n.scrollSensitivity && (r = e(document).scrollLeft(e(document).scrollLeft() + n.scrollSpeed))), r !== !1 && e.ui.ddmanager && !n.dropBehaviour && e.ui.ddmanager.prepareOffsets(this, t) } this.positionAbs = this._convertPositionTo("absolute"); if (!this.options.axis || this.options.axis != "y") this.helper[0].style.left = this.position.left + "px"; if (!this.options.axis || this.options.axis != "x") this.helper[0].style.top = this.position.top + "px"; for (var i = this.items.length - 1; i >= 0; i--) { var s = this.items[i], o = s.item[0], u = this._intersectsWithPointer(s); if (!u) continue; if (s.instance !== this.currentContainer) continue; if (o != this.currentItem[0] && this.placeholder[u == 1 ? "next" : "prev"]()[0] != o && !e.contains(this.placeholder[0], o) && (this.options.type == "semi-dynamic" ? !e.contains(this.element[0], o) : !0)) { this.direction = u == 1 ? "down" : "up"; if (this.options.tolerance != "pointer" && !this._intersectsWithSides(s)) break; this._rearrange(t, s), this._trigger("change", t, this._uiHash()); break } } return this._contactContainers(t), e.ui.ddmanager && e.ui.ddmanager.drag(this, t), this._trigger("sort", t, this._uiHash()), this.lastPositionAbs = this.positionAbs, !1 }, _mouseStop: function(t, n) { if (!t) return; e.ui.ddmanager && !this.options.dropBehaviour && e.ui.ddmanager.drop(this, t); if (this.options.revert) { var r = this, i = this.placeholder.offset(); this.reverting = !0, e(this.helper).animate({ left: i.left - this.offset.parent.left - this.margins.left + (this.offsetParent[0] == document.body ? 0 : this.offsetParent[0].scrollLeft), top: i.top - this.offset.parent.top - this.margins.top + (this.offsetParent[0] == document.body ? 0 : this.offsetParent[0].scrollTop) }, parseInt(this.options.revert, 10) || 500, function() { r._clear(t) }) } else this._clear(t, n); return !1 }, cancel: function() { if (this.dragging) { this._mouseUp({ target: null }), this.options.helper == "original" ? this.currentItem.css(this._storedCSS).removeClass("ui-sortable-helper") : this.currentItem.show(); for (var t = this.containers.length - 1; t >= 0; t--) this.containers[t]._trigger("deactivate", null, this._uiHash(this)), this.containers[t].containerCache.over && (this.containers[t]._trigger("out", null, this._uiHash(this)), this.containers[t].containerCache.over = 0) } return this.placeholder && (this.placeholder[0].parentNode && this.placeholder[0].parentNode.removeChild(this.placeholder[0]), this.options.helper != "original" && this.helper && this.helper[0].parentNode && this.helper.remove(), e.extend(this, { helper: null, dragging: !1, reverting: !1, _noFinalSort: null }), this.domPosition.prev ? e(this.domPosition.prev).after(this.currentItem) : e(this.domPosition.parent).prepend(this.currentItem)), this }, serialize: function(t) { var n = this._getItemsAsjQuery(t && t.connected), r = []; return t = t || {}, e(n).each(function() { var n = (e(t.item || this).attr(t.attribute || "id") || "").match(t.expression || /(.+)[-=_](.+)/); n && r.push((t.key || n[1] + "[]") + "=" + (t.key && t.expression ? n[1] : n[2])) }), !r.length && t.key && r.push(t.key + "="), r.join("&") }, toArray: function(t) { var n = this._getItemsAsjQuery(t && t.connected), r = []; return t = t || {}, n.each(function() { r.push(e(t.item || this).attr(t.attribute || "id") || "") }), r }, _intersectsWith: function(e) { var t = this.positionAbs.left, n = t + this.helperProportions.width, r = this.positionAbs.top, i = r + this.helperProportions.height, s = e.left, o = s + e.width, u = e.top, a = u + e.height, f = this.offset.click.top, l = this.offset.click.left, c = r + f > u && r + f < a && t + l > s && t + l < o; return this.options.tolerance == "pointer" || this.options.forcePointerForContainers || this.options.tolerance != "pointer" && this.helperProportions[this.floating ? "width" : "height"] > e[this.floating ? "width" : "height"] ? c : s < t + this.helperProportions.width / 2 && n - this.helperProportions.width / 2 < o && u < r + this.helperProportions.height / 2 && i - this.helperProportions.height / 2 < a }, _intersectsWithPointer: function(t) { var n = this.options.axis === "x" || e.ui.isOverAxis(this.positionAbs.top + this.offset.click.top, t.top, t.height), r = this.options.axis === "y" || e.ui.isOverAxis(this.positionAbs.left + this.offset.click.left, t.left, t.width), i = n && r, s = this._getDragVerticalDirection(), o = this._getDragHorizontalDirection(); return i ? this.floating ? o && o == "right" || s == "down" ? 2 : 1 : s && (s == "down" ? 2 : 1) : !1 }, _intersectsWithSides: function(t) { var n = e.ui.isOverAxis(this.positionAbs.top + this.offset.click.top, t.top + t.height / 2, t.height), r = e.ui.isOverAxis(this.positionAbs.left + this.offset.click.left, t.left + t.width / 2, t.width), i = this._getDragVerticalDirection(), s = this._getDragHorizontalDirection(); return this.floating && s ? s == "right" && r || s == "left" && !r : i && (i == "down" && n || i == "up" && !n) }, _getDragVerticalDirection: function() { var e = this.positionAbs.top - this.lastPositionAbs.top; return e != 0 && (e > 0 ? "down" : "up") }, _getDragHorizontalDirection: function() { var e = this.positionAbs.left - this.lastPositionAbs.left; return e != 0 && (e > 0 ? "right" : "left") }, refresh: function(e) { return this._refreshItems(e), this.refreshPositions(), this }, _connectWith: function() { var e = this.options; return e.connectWith.constructor == String ? [e.connectWith] : e.connectWith }, _getItemsAsjQuery: function(t) { var n = [], r = [], i = this._connectWith(); if (i && t) for (var s = i.length - 1; s >= 0; s--) { var o = e(i[s]); for (var u = o.length - 1; u >= 0; u--) { var a = e.data(o[u], this.widgetName); a && a != this && !a.options.disabled && r.push([e.isFunction(a.options.items) ? a.options.items.call(a.element) : e(a.options.items, a.element).not(".ui-sortable-helper").not(".ui-sortable-placeholder"), a]) } } r.push([e.isFunction(this.options.items) ? this.options.items.call(this.element, null, { options: this.options, item: this.currentItem }) : e(this.options.items, this.element).not(".ui-sortable-helper").not(".ui-sortable-placeholder"), this]); for (var s = r.length - 1; s >= 0; s--) r[s][0].each(function() { n.push(this) }); return e(n) }, _removeCurrentsFromItems: function() { var e = this.currentItem.find(":data(" + this.widgetName + "-item)"); for (var t = 0; t < this.items.length; t++) for (var n = 0; n < e.length; n++) e[n] == this.items[t].item[0] && this.items.splice(t, 1) }, _refreshItems: function(t) { this.items = [], this.containers = [this]; var n = this.items, r = [[e.isFunction(this.options.items) ? this.options.items.call(this.element[0], t, { item: this.currentItem }) : e(this.options.items, this.element), this]], i = this._connectWith(); if (i && this.ready) for (var s = i.length - 1; s >= 0; s--) { var o = e(i[s]); for (var u = o.length - 1; u >= 0; u--) { var a = e.data(o[u], this.widgetName); a && a != this && !a.options.disabled && (r.push([e.isFunction(a.options.items) ? a.options.items.call(a.element[0], t, { item: this.currentItem }) : e(a.options.items, a.element), a]), this.containers.push(a)) } } for (var s = r.length - 1; s >= 0; s--) { var f = r[s][1], l = r[s][0]; for (var u = 0, c = l.length; u < c; u++) { var h = e(l[u]); h.data(this.widgetName + "-item", f), n.push({ item: h, instance: f, width: 0, height: 0, left: 0, top: 0 }) } } }, refreshPositions: function(t) { this.offsetParent && this.helper && (this.offset.parent = this._getParentOffset()); for (var n = this.items.length - 1; n >= 0; n--) { var r = this.items[n]; if (r.instance != this.currentContainer && this.currentContainer && r.item[0] != this.currentItem[0]) continue; var i = this.options.toleranceElement ? e(this.options.toleranceElement, r.item) : r.item; t || (r.width = i.outerWidth(), r.height = i.outerHeight()); var s = i.offset(); r.left = s.left, r.top = s.top } if (this.options.custom && this.options.custom.refreshContainers) this.options.custom.refreshContainers.call(this); else for (var n = this.containers.length - 1; n >= 0; n--) { var s = this.containers[n].element.offset(); this.containers[n].containerCache.left = s.left, this.containers[n].containerCache.top = s.top, this.containers[n].containerCache.width = this.containers[n].element.outerWidth(), this.containers[n].containerCache.height = this.containers[n].element.outerHeight() } return this }, _createPlaceholder: function(t) { t = t || this; var n = t.options; if (!n.placeholder || n.placeholder.constructor == String) { var r = n.placeholder; n.placeholder = { element: function() { var n = e(document.createElement(t.currentItem[0].nodeName)).addClass(r || t.currentItem[0].className + " ui-sortable-placeholder").removeClass("ui-sortable-helper")[0]; return r || (n.style.visibility = "hidden"), n }, update: function(e, i) { if (r && !n.forcePlaceholderSize) return; i.height() || i.height(t.currentItem.innerHeight() - parseInt(t.currentItem.css("paddingTop") || 0, 10) - parseInt(t.currentItem.css("paddingBottom") || 0, 10)), i.width() || i.width(t.currentItem.innerWidth() - parseInt(t.currentItem.css("paddingLeft") || 0, 10) - parseInt(t.currentItem.css("paddingRight") || 0, 10)) } } } t.placeholder = e(n.placeholder.element.call(t.element, t.currentItem)), t.currentItem.after(t.placeholder), n.placeholder.update(t, t.placeholder) }, _contactContainers: function(t) { var n = null, r = null; for (var i = this.containers.length - 1; i >= 0; i--) { if (e.contains(this.currentItem[0], this.containers[i].element[0])) continue; if (this._intersectsWith(this.containers[i].containerCache)) { if (n && e.contains(this.containers[i].element[0], n.element[0])) continue; n = this.containers[i], r = i } else this.containers[i].containerCache.over && (this.containers[i]._trigger("out", t, this._uiHash(this)), this.containers[i].containerCache.over = 0) } if (!n) return; if (this.containers.length === 1) this.containers[r]._trigger("over", t, this._uiHash(this)), this.containers[r].containerCache.over = 1; else if (this.currentContainer != this.containers[r]) { var s = 1e4, o = null, u = this.positionAbs[this.containers[r].floating ? "left" : "top"]; for (var a = this.items.length - 1; a >= 0; a--) { if (!e.contains(this.containers[r].element[0], this.items[a].item[0])) continue; var f = this.containers[r].floating ? this.items[a].item.offset().left : this.items[a].item.offset().top; Math.abs(f - u) < s && (s = Math.abs(f - u), o = this.items[a], this.direction = f - u > 0 ? "down" : "up") } if (!o && !this.options.dropOnEmpty) return; this.currentContainer = this.containers[r], o ? this._rearrange(t, o, null, !0) : this._rearrange(t, null, this.containers[r].element, !0), this._trigger("change", t, this._uiHash()), this.containers[r]._trigger("change", t, this._uiHash(this)), this.options.placeholder.update(this.currentContainer, this.placeholder), this.containers[r]._trigger("over", t, this._uiHash(this)), this.containers[r].containerCache.over = 1 } }, _createHelper: function(t) { var n = this.options, r = e.isFunction(n.helper) ? e(n.helper.apply(this.element[0], [t, this.currentItem])) : n.helper == "clone" ? this.currentItem.clone() : this.currentItem; return r.parents("body").length || e(n.appendTo != "parent" ? n.appendTo : this.currentItem[0].parentNode)[0].appendChild(r[0]), r[0] == this.currentItem[0] && (this._storedCSS = { width: this.currentItem[0].style.width, height: this.currentItem[0].style.height, position: this.currentItem.css("position"), top: this.currentItem.css("top"), left: this.currentItem.css("left") }), (r[0].style.width == "" || n.forceHelperSize) && r.width(this.currentItem.width()), (r[0].style.height == "" || n.forceHelperSize) && r.height(this.currentItem.height()), r }, _adjustOffsetFromHelper: function(t) { typeof t == "string" && (t = t.split(" ")), e.isArray(t) && (t = { left: +t[0], top: +t[1] || 0 }), "left" in t && (this.offset.click.left = t.left + this.margins.left), "right" in t && (this.offset.click.left = this.helperProportions.width - t.right + this.margins.left), "top" in t && (this.offset.click.top = t.top + this.margins.top), "bottom" in t && (this.offset.click.top = this.helperProportions.height - t.bottom + this.margins.top) }, _getParentOffset: function() { this.offsetParent = this.helper.offsetParent(); var t = this.offsetParent.offset(); this.cssPosition == "absolute" && this.scrollParent[0] != document && e.contains(this.scrollParent[0], this.offsetParent[0]) && (t.left += this.scrollParent.scrollLeft(), t.top += this.scrollParent.scrollTop()); if (this.offsetParent[0] == document.body || this.offsetParent[0].tagName && this.offsetParent[0].tagName.toLowerCase() == "html" && e.browser.msie) t = { top: 0, left: 0 }; return { top: t.top + (parseInt(this.offsetParent.css("borderTopWidth"), 10) || 0), left: t.left + (parseInt(this.offsetParent.css("borderLeftWidth"), 10) || 0)} }, _getRelativeOffset: function() { if (this.cssPosition == "relative") { var e = this.currentItem.position(); return { top: e.top - (parseInt(this.helper.css("top"), 10) || 0) + this.scrollParent.scrollTop(), left: e.left - (parseInt(this.helper.css("left"), 10) || 0) + this.scrollParent.scrollLeft()} } return { top: 0, left: 0} }, _cacheMargins: function() { this.margins = { left: parseInt(this.currentItem.css("marginLeft"), 10) || 0, top: parseInt(this.currentItem.css("marginTop"), 10) || 0} }, _cacheHelperProportions: function() { this.helperProportions = { width: this.helper.outerWidth(), height: this.helper.outerHeight()} }, _setContainment: function() { var t = this.options; t.containment == "parent" && (t.containment = this.helper[0].parentNode); if (t.containment == "document" || t.containment == "window") this.containment = [0 - this.offset.relative.left - this.offset.parent.left, 0 - this.offset.relative.top - this.offset.parent.top, e(t.containment == "document" ? document : window).width() - this.helperProportions.width - this.margins.left, (e(t.containment == "document" ? document : window).height() || document.body.parentNode.scrollHeight) - this.helperProportions.height - this.margins.top]; if (!/^(document|window|parent)$/.test(t.containment)) { var n = e(t.containment)[0], r = e(t.containment).offset(), i = e(n).css("overflow") != "hidden"; this.containment = [r.left + (parseInt(e(n).css("borderLeftWidth"), 10) || 0) + (parseInt(e(n).css("paddingLeft"), 10) || 0) - this.margins.left, r.top + (parseInt(e(n).css("borderTopWidth"), 10) || 0) + (parseInt(e(n).css("paddingTop"), 10) || 0) - this.margins.top, r.left + (i ? Math.max(n.scrollWidth, n.offsetWidth) : n.offsetWidth) - (parseInt(e(n).css("borderLeftWidth"), 10) || 0) - (parseInt(e(n).css("paddingRight"), 10) || 0) - this.helperProportions.width - this.margins.left, r.top + (i ? Math.max(n.scrollHeight, n.offsetHeight) : n.offsetHeight) - (parseInt(e(n).css("borderTopWidth"), 10) || 0) - (parseInt(e(n).css("paddingBottom"), 10) || 0) - this.helperProportions.height - this.margins.top] } }, _convertPositionTo: function(t, n) { n || (n = this.position); var r = t == "absolute" ? 1 : -1, i = this.options, s = this.cssPosition != "absolute" || this.scrollParent[0] != document && !!e.contains(this.scrollParent[0], this.offsetParent[0]) ? this.scrollParent : this.offsetParent, o = /(html|body)/i.test(s[0].tagName); return { top: n.top + this.offset.relative.top * r + this.offset.parent.top * r - (this.cssPosition == "fixed" ? -this.scrollParent.scrollTop() : o ? 0 : s.scrollTop()) * r, left: n.left + this.offset.relative.left * r + this.offset.parent.left * r - (this.cssPosition == "fixed" ? -this.scrollParent.scrollLeft() : o ? 0 : s.scrollLeft()) * r} }, _generatePosition: function(t) { var n = this.options, r = this.cssPosition != "absolute" || this.scrollParent[0] != document && !!e.contains(this.scrollParent[0], this.offsetParent[0]) ? this.scrollParent : this.offsetParent, i = /(html|body)/i.test(r[0].tagName); this.cssPosition == "relative" && (this.scrollParent[0] == document || this.scrollParent[0] == this.offsetParent[0]) && (this.offset.relative = this._getRelativeOffset()); var s = t.pageX, o = t.pageY; if (this.originalPosition) { this.containment && (t.pageX - this.offset.click.left < this.containment[0] && (s = this.containment[0] + this.offset.click.left), t.pageY - this.offset.click.top < this.containment[1] && (o = this.containment[1] + this.offset.click.top), t.pageX - this.offset.click.left > this.containment[2] && (s = this.containment[2] + this.offset.click.left), t.pageY - this.offset.click.top > this.containment[3] && (o = this.containment[3] + this.offset.click.top)); if (n.grid) { var u = this.originalPageY + Math.round((o - this.originalPageY) / n.grid[1]) * n.grid[1]; o = this.containment ? u - this.offset.click.top < this.containment[1] || u - this.offset.click.top > this.containment[3] ? u - this.offset.click.top < this.containment[1] ? u + n.grid[1] : u - n.grid[1] : u : u; var a = this.originalPageX + Math.round((s - this.originalPageX) / n.grid[0]) * n.grid[0]; s = this.containment ? a - this.offset.click.left < this.containment[0] || a - this.offset.click.left > this.containment[2] ? a - this.offset.click.left < this.containment[0] ? a + n.grid[0] : a - n.grid[0] : a : a } } return { top: o - this.offset.click.top - this.offset.relative.top - this.offset.parent.top + (this.cssPosition == "fixed" ? -this.scrollParent.scrollTop() : i ? 0 : r.scrollTop()), left: s - this.offset.click.left - this.offset.relative.left - this.offset.parent.left + (this.cssPosition == "fixed" ? -this.scrollParent.scrollLeft() : i ? 0 : r.scrollLeft())} }, _rearrange: function(e, t, n, r) { n ? n[0].appendChild(this.placeholder[0]) : t.item[0].parentNode.insertBefore(this.placeholder[0], this.direction == "down" ? t.item[0] : t.item[0].nextSibling), this.counter = this.counter ? ++this.counter : 1; var i = this.counter; this._delay(function() { i == this.counter && this.refreshPositions(!r) }) }, _clear: function(t, n) { this.reverting = !1; var r = []; !this._noFinalSort && this.currentItem.parent().length && this.placeholder.before(this.currentItem), this._noFinalSort = null; if (this.helper[0] == this.currentItem[0]) { for (var i in this._storedCSS) if (this._storedCSS[i] == "auto" || this._storedCSS[i] == "static") this._storedCSS[i] = ""; this.currentItem.css(this._storedCSS).removeClass("ui-sortable-helper") } else this.currentItem.show(); this.fromOutside && !n && r.push(function(e) { this._trigger("receive", e, this._uiHash(this.fromOutside)) }), (this.fromOutside || this.domPosition.prev != this.currentItem.prev().not(".ui-sortable-helper")[0] || this.domPosition.parent != this.currentItem.parent()[0]) && !n && r.push(function(e) { this._trigger("update", e, this._uiHash()) }), this !== this.currentContainer && (n || (r.push(function(e) { this._trigger("remove", e, this._uiHash()) }), r.push(function(e) { return function(t) { e._trigger("receive", t, this._uiHash(this)) } } .call(this, this.currentContainer)), r.push(function(e) { return function(t) { e._trigger("update", t, this._uiHash(this)) } } .call(this, this.currentContainer)))); for (var i = this.containers.length - 1; i >= 0; i--) n || r.push(function(e) { return function(t) { e._trigger("deactivate", t, this._uiHash(this)) } } .call(this, this.containers[i])), this.containers[i].containerCache.over && (r.push(function(e) { return function(t) { e._trigger("out", t, this._uiHash(this)) } } .call(this, this.containers[i])), this.containers[i].containerCache.over = 0); this._storedCursor && e("body").css("cursor", this._storedCursor), this._storedOpacity && this.helper.css("opacity", this._storedOpacity), this._storedZIndex && this.helper.css("zIndex", this._storedZIndex == "auto" ? "" : this._storedZIndex), this.dragging = !1; if (this.cancelHelperRemoval) { if (!n) { this._trigger("beforeStop", t, this._uiHash()); for (var i = 0; i < r.length; i++) r[i].call(this, t); this._trigger("stop", t, this._uiHash()) } return this.fromOutside = !1, !1 } n || this._trigger("beforeStop", t, this._uiHash()), this.placeholder[0].parentNode.removeChild(this.placeholder[0]), this.helper[0] != this.currentItem[0] && this.helper.remove(), this.helper = null; if (!n) { for (var i = 0; i < r.length; i++) r[i].call(this, t); this._trigger("stop", t, this._uiHash()) } return this.fromOutside = !1, !0 }, _trigger: function() { e.Widget.prototype._trigger.apply(this, arguments) === !1 && this.cancel() }, _uiHash: function(t) { var n = t || this; return { helper: n.helper, placeholder: n.placeholder || e([]), position: n.position, originalPosition: n.originalPosition, offset: n.positionAbs, item: n.currentItem, sender: t ? t.element : null} } }) } (jQuery), jQuery.effects || function(e, t) { var n = e.uiBackCompat !== !1, r = "ui-effects-"; e.effects = { effect: {} }, function(t, n) { function p(e, t, n) { var r = a[t.type] || {}; return e == null ? n || !t.def ? null : t.def : (e = r.floor ? ~ ~e : parseFloat(e), isNaN(e) ? t.def : r.mod ? (e + r.mod) % r.mod : 0 > e ? 0 : r.max < e ? r.max : e) } function d(e) { var n = o(), r = n._rgba = []; return e = e.toLowerCase(), h(s, function(t, i) { var s, o = i.re.exec(e), a = o && i.parse(o), f = i.space || "rgba"; if (a) return s = n[f](a), n[u[f].cache] = s[u[f].cache], r = n._rgba = s._rgba, !1 }), r.length ? (r.join() === "0,0,0,0" && t.extend(r, c.transparent), n) : c[e] } function v(e, t, n) { return n = (n + 1) % 1, n * 6 < 1 ? e + (t - e) * n * 6 : n * 2 < 1 ? t : n * 3 < 2 ? e + (t - e) * (2 / 3 - n) * 6 : e } var r = "backgroundColor borderBottomColor borderLeftColor borderRightColor borderTopColor color columnRuleColor outlineColor textDecorationColor textEmphasisColor".split(" "), i = /^([\-+])=\s*(\d+\.?\d*)/, s = [{ re: /rgba?\(\s*(\d{1,3})\s*,\s*(\d{1,3})\s*,\s*(\d{1,3})\s*(?:,\s*(\d+(?:\.\d+)?)\s*)?\)/, parse: function(e) { return [e[1], e[2], e[3], e[4]] } }, { re: /rgba?\(\s*(\d+(?:\.\d+)?)\%\s*,\s*(\d+(?:\.\d+)?)\%\s*,\s*(\d+(?:\.\d+)?)\%\s*(?:,\s*(\d+(?:\.\d+)?)\s*)?\)/, parse: function(e) { return [e[1] * 2.55, e[2] * 2.55, e[3] * 2.55, e[4]] } }, { re: /#([a-f0-9]{2})([a-f0-9]{2})([a-f0-9]{2})/, parse: function(e) { return [parseInt(e[1], 16), parseInt(e[2], 16), parseInt(e[3], 16)] } }, { re: /#([a-f0-9])([a-f0-9])([a-f0-9])/, parse: function(e) { return [parseInt(e[1] + e[1], 16), parseInt(e[2] + e[2], 16), parseInt(e[3] + e[3], 16)] } }, { re: /hsla?\(\s*(\d+(?:\.\d+)?)\s*,\s*(\d+(?:\.\d+)?)\%\s*,\s*(\d+(?:\.\d+)?)\%\s*(?:,\s*(\d+(?:\.\d+)?)\s*)?\)/, space: "hsla", parse: function(e) { return [e[1], e[2] / 100, e[3] / 100, e[4]] } }], o = t.Color = function(e, n, r, i) { return new t.Color.fn.parse(e, n, r, i) }, u = { rgba: { props: { red: { idx: 0, type: "byte" }, green: { idx: 1, type: "byte" }, blue: { idx: 2, type: "byte"}} }, hsla: { props: { hue: { idx: 0, type: "degrees" }, saturation: { idx: 1, type: "percent" }, lightness: { idx: 2, type: "percent"}}} }, a = { "byte": { floor: !0, max: 255 }, percent: { max: 1 }, degrees: { mod: 360, floor: !0} }, f = o.support = {}, l = t("

")[0], c, h = t.each; l.style.cssText = "background-color:rgba(1,1,1,.5)", f.rgba = l.style.backgroundColor.indexOf("rgba") > -1, h(u, function(e, t) { t.cache = "_" + e, t.props.alpha = { idx: 3, type: "percent", def: 1} }), o.fn = t.extend(o.prototype, { parse: function(r, i, s, a) { if (r === n) return this._rgba = [null, null, null, null], this; if (r.jquery || r.nodeType) r = t(r).css(i), i = n; var f = this, l = t.type(r), v = this._rgba = [], m; i !== n && (r = [r, i, s, a], l = "array"); if (l === "string") return this.parse(d(r) || c._default); if (l === "array") return h(u.rgba.props, function(e, t) { v[t.idx] = p(r[t.idx], t) }), this; if (l === "object") return r instanceof o ? h(u, function(e, t) { r[t.cache] && (f[t.cache] = r[t.cache].slice()) }) : h(u, function(t, n) { var i = n.cache; h(n.props, function(e, t) { if (!f[i] && n.to) { if (e === "alpha" || r[e] == null) return; f[i] = n.to(f._rgba) } f[i][t.idx] = p(r[e], t, !0) }), f[i] && e.inArray(null, f[i].slice(0, 3)) < 0 && (f[i][3] = 1, n.from && (f._rgba = n.from(f[i]))) }), this }, is: function(e) { var t = o(e), n = !0, r = this; return h(u, function(e, i) { var s, o = t[i.cache]; return o && (s = r[i.cache] || i.to && i.to(r._rgba) || [], h(i.props, function(e, t) { if (o[t.idx] != null) return n = o[t.idx] === s[t.idx], n })), n }), n }, _space: function() { var e = [], t = this; return h(u, function(n, r) { t[r.cache] && e.push(n) }), e.pop() }, transition: function(e, t) { var n = o(e), r = n._space(), i = u[r], s = this.alpha() === 0 ? o("transparent") : this, f = s[i.cache] || i.to(s._rgba), l = f.slice(); return n = n[i.cache], h(i.props, function(e, r) { var i = r.idx, s = f[i], o = n[i], u = a[r.type] || {}; if (o === null) return; s === null ? l[i] = o : (u.mod && (o - s > u.mod / 2 ? s += u.mod : s - o > u.mod / 2 && (s -= u.mod)), l[i] = p((o - s) * t + s, r)) }), this[r](l) }, blend: function(e) { if (this._rgba[3] === 1) return this; var n = this._rgba.slice(), r = n.pop(), i = o(e)._rgba; return o(t.map(n, function(e, t) { return (1 - r) * i[t] + r * e })) }, toRgbaString: function() { var e = "rgba(", n = t.map(this._rgba, function(e, t) { return e == null ? t > 2 ? 1 : 0 : e }); return n[3] === 1 && (n.pop(), e = "rgb("), e + n.join() + ")" }, toHslaString: function() { var e = "hsla(", n = t.map(this.hsla(), function(e, t) { return e == null && (e = t > 2 ? 1 : 0), t && t < 3 && (e = Math.round(e * 100) + "%"), e }); return n[3] === 1 && (n.pop(), e = "hsl("), e + n.join() + ")" }, toHexString: function(e) { var n = this._rgba.slice(), r = n.pop(); return e && n.push(~ ~(r * 255)), "#" + t.map(n, function(e, t) { return e = (e || 0).toString(16), e.length === 1 ? "0" + e : e }).join("") }, toString: function() { return this._rgba[3] === 0 ? "transparent" : this.toRgbaString() } }), o.fn.parse.prototype = o.fn, u.hsla.to = function(e) { if (e[0] == null || e[1] == null || e[2] == null) return [null, null, null, e[3]]; var t = e[0] / 255, n = e[1] / 255, r = e[2] / 255, i = e[3], s = Math.max(t, n, r), o = Math.min(t, n, r), u = s - o, a = s + o, f = a * .5, l, c; return o === s ? l = 0 : t === s ? l = 60 * (n - r) / u + 360 : n === s ? l = 60 * (r - t) / u + 120 : l = 60 * (t - n) / u + 240, f === 0 || f === 1 ? c = f : f <= .5 ? c = u / a : c = u / (2 - a), [Math.round(l) % 360, c, f, i == null ? 1 : i] }, u.hsla.from = function(e) { if (e[0] == null || e[1] == null || e[2] == null) return [null, null, null, e[3]]; var t = e[0] / 360, n = e[1], r = e[2], i = e[3], s = r <= .5 ? r * (1 + n) : r + n - r * n, o = 2 * r - s, u, a, f; return [Math.round(v(o, s, t + 1 / 3) * 255), Math.round(v(o, s, t) * 255), Math.round(v(o, s, t - 1 / 3) * 255), i] }, h(u, function(e, r) { var s = r.props, u = r.cache, a = r.to, f = r.from; o.fn[e] = function(e) { a && !this[u] && (this[u] = a(this._rgba)); if (e === n) return this[u].slice(); var r, i = t.type(e), l = i === "array" || i === "object" ? e : arguments, c = this[u].slice(); return h(s, function(e, t) { var n = l[i === "object" ? e : t.idx]; n == null && (n = c[t.idx]), c[t.idx] = p(n, t) }), f ? (r = o(f(c)), r[u] = c, r) : o(c) }, h(s, function(n, r) { if (o.fn[n]) return; o.fn[n] = function(s) { var o = t.type(s), u = n === "alpha" ? this._hsla ? "hsla" : "rgba" : e, a = this[u](), f = a[r.idx], l; return o === "undefined" ? f : (o === "function" && (s = s.call(this, f), o = t.type(s)), s == null && r.empty ? this : (o === "string" && (l = i.exec(s), l && (s = f + parseFloat(l[2]) * (l[1] === "+" ? 1 : -1))), a[r.idx] = s, this[u](a))) } }) }), h(r, function(e, n) { t.cssHooks[n] = { set: function(e, r) { var i, s, u = ""; if (t.type(r) !== "string" || (i = d(r))) { r = o(i || r); if (!f.rgba && r._rgba[3] !== 1) { s = n === "backgroundColor" ? e.parentNode : e; while ((u === "" || u === "transparent") && s && s.style) try { u = t.css(s, "backgroundColor"), s = s.parentNode } catch (a) { } r = r.blend(u && u !== "transparent" ? u : "_default") } r = r.toRgbaString() } try { e.style[n] = r } catch (r) { } } }, t.fx.step[n] = function(e) { e.colorInit || (e.start = o(e.elem, n), e.end = o(e.end), e.colorInit = !0), t.cssHooks[n].set(e.elem, e.start.transition(e.end, e.pos)) } }), t.cssHooks.borderColor = { expand: function(e) { var t = {}; return h(["Top", "Right", "Bottom", "Left"], function(n, r) { t["border" + r + "Color"] = e }), t } }, c = t.Color.names = { aqua: "#00ffff", black: "#000000", blue: "#0000ff", fuchsia: "#ff00ff", gray: "#808080", green: "#008000", lime: "#00ff00", maroon: "#800000", navy: "#000080", olive: "#808000", purple: "#800080", red: "#ff0000", silver: "#c0c0c0", teal: "#008080", white: "#ffffff", yellow: "#ffff00", transparent: [null, null, null, 0], _default: "#ffffff"} } (jQuery), function() { function i() { var t = this.ownerDocument.defaultView ? this.ownerDocument.defaultView.getComputedStyle(this, null) : this.currentStyle, n = {}, r, i, s; if (t && t.length && t[0] && t[t[0]]) { s = t.length; while (s--) r = t[s], typeof t[r] == "string" && (n[e.camelCase(r)] = t[r]) } else for (r in t) typeof t[r] == "string" && (n[r] = t[r]); return n } function s(t, n) { var i = {}, s, o; for (s in n) o = n[s], t[s] !== o && !r[s] && (e.fx.step[s] || !isNaN(parseFloat(o))) && (i[s] = o); return i } var n = ["add", "remove", "toggle"], r = { border: 1, borderBottom: 1, borderColor: 1, borderLeft: 1, borderRight: 1, borderTop: 1, borderWidth: 1, margin: 1, padding: 1 }; e.each(["borderLeftStyle", "borderRightStyle", "borderBottomStyle", "borderTopStyle"], function(t, n) { e.fx.step[n] = function(e) { if (e.end !== "none" && !e.setAttr || e.pos === 1 && !e.setAttr) jQuery.style(e.elem, n, e.end), e.setAttr = !0 } }), e.effects.animateClass = function(t, r, o, u) { var a = e.speed(r, o, u); return this.queue(function() { var r = e(this), o = r.attr("class") || "", u, f = a.children ? r.find("*").andSelf() : r; f = f.map(function() { var t = e(this); return { el: t, start: i.call(this)} }), u = function() { e.each(n, function(e, n) { t[n] && r[n + "Class"](t[n]) }) }, u(), f = f.map(function() { return this.end = i.call(this.el[0]), this.diff = s(this.start, this.end), this }), r.attr("class", o), f = f.map(function() { var t = this, n = e.Deferred(), r = jQuery.extend({}, a, { queue: !1, complete: function() { n.resolve(t) } }); return this.el.animate(this.diff, r), n.promise() }), e.when.apply(e, f.get()).done(function() { u(), e.each(arguments, function() { var t = this.el; e.each(this.diff, function(e) { t.css(e, "") }) }), a.complete.call(r[0]) }) }) }, e.fn.extend({ _addClass: e.fn.addClass, addClass: function(t, n, r, i) { return n ? e.effects.animateClass.call(this, { add: t }, n, r, i) : this._addClass(t) }, _removeClass: e.fn.removeClass, removeClass: function(t, n, r, i) { return n ? e.effects.animateClass.call(this, { remove: t }, n, r, i) : this._removeClass(t) }, _toggleClass: e.fn.toggleClass, toggleClass: function(n, r, i, s, o) { return typeof r == "boolean" || r === t ? i ? e.effects.animateClass.call(this, r ? { add: n} : { remove: n }, i, s, o) : this._toggleClass(n, r) : e.effects.animateClass.call(this, { toggle: n }, r, i, s) }, switchClass: function(t, n, r, i, s) { return e.effects.animateClass.call(this, { add: n, remove: t }, r, i, s) } }) } (), function() { function i(n, r, i, s) { e.isPlainObject(n) && (r = n, n = n.effect), n = { effect: n }, r === t && (r = {}), e.isFunction(r) && (s = r, i = null, r = {}); if (typeof r == "number" || e.fx.speeds[r]) s = i, i = r, r = {}; return e.isFunction(i) && (s = i, i = null), r && e.extend(n, r), i = i || r.duration, n.duration = e.fx.off ? 0 : typeof i == "number" ? i : i in e.fx.speeds ? e.fx.speeds[i] : e.fx.speeds._default, n.complete = s || r.complete, n } function s(t) { return !t || typeof t == "number" || e.fx.speeds[t] ? !0 : typeof t == "string" && !e.effects.effect[t] ? n && e.effects[t] ? !1 : !0 : !1 } e.extend(e.effects, { version: "1.9.0", save: function(e, t) { for (var n = 0; n < t.length; n++) t[n] !== null && e.data(r + t[n], e[0].style[t[n]]) }, restore: function(e, n) { var i, s; for (s = 0; s < n.length; s++) n[s] !== null && (i = e.data(r + n[s]), i === t && (i = ""), e.css(n[s], i)) }, setMode: function(e, t) { return t === "toggle" && (t = e.is(":hidden") ? "show" : "hide"), t }, getBaseline: function(e, t) { var n, r; switch (e[0]) { case "top": n = 0; break; case "middle": n = .5; break; case "bottom": n = 1; break; default: n = e[0] / t.height } switch (e[1]) { case "left": r = 0; break; case "center": r = .5; break; case "right": r = 1; break; default: r = e[1] / t.width } return { x: r, y: n} }, createWrapper: function(t) { if (t.parent().is(".ui-effects-wrapper")) return t.parent(); var n = { width: t.outerWidth(!0), height: t.outerHeight(!0), "float": t.css("float") }, r = e("

").addClass("ui-effects-wrapper").css({ fontSize: "100%", background: "transparent", border: "none", margin: 0, padding: 0 }), i = { width: t.width(), height: t.height() }, s = document.activeElement; try { s.id } catch (o) { s = document.body } return t.wrap(r), (t[0] === s || e.contains(t[0], s)) && e(s).focus(), r = t.parent(), t.css("position") === "static" ? (r.css({ position: "relative" }), t.css({ position: "relative" })) : (e.extend(n, { position: t.css("position"), zIndex: t.css("z-index") }), e.each(["top", "left", "bottom", "right"], function(e, r) { n[r] = t.css(r), isNaN(parseInt(n[r], 10)) && (n[r] = "auto") }), t.css({ position: "relative", top: 0, left: 0, right: "auto", bottom: "auto" })), t.css(i), r.css(n).show() }, removeWrapper: function(t) { var n = document.activeElement; return t.parent().is(".ui-effects-wrapper") && (t.parent().replaceWith(t), (t[0] === n || e.contains(t[0], n)) && e(n).focus()), t }, setTransition: function(t, n, r, i) { return i = i || {}, e.each(n, function(e, n) { var s = t.cssUnit(n); s[0] > 0 && (i[n] = s[0] * r + s[1]) }), i } }), e.fn.extend({ effect: function(t, r, s, o) { function h(t) { function s() { e.isFunction(r) && r.call(n[0]), e.isFunction(t) && t() } var n = e(this), r = u.complete, i = u.mode; (n.is(":hidden") ? i === "hide" : i === "show") ? s() : l.call(n[0], u, s) } var u = i.apply(this, arguments), a = u.mode, f = u.queue, l = e.effects.effect[u.effect], c = !l && n && e.effects[u.effect]; return e.fx.off || !l && !c ? a ? this[a](u.duration, u.complete) : this.each(function() { u.complete && u.complete.call(this) }) : l ? f === !1 ? this.each(h) : this.queue(f || "fx", h) : c.call(this, { options: u, duration: u.duration, callback: u.complete, mode: u.mode }) }, _show: e.fn.show, show: function(e) { if (s(e)) return this._show.apply(this, arguments); var t = i.apply(this, arguments); return t.mode = "show", this.effect.call(this, t) }, _hide: e.fn.hide, hide: function(e) { if (s(e)) return this._hide.apply(this, arguments); var t = i.apply(this, arguments); return t.mode = "hide", this.effect.call(this, t) }, __toggle: e.fn.toggle, toggle: function(t) { if (s(t) || typeof t == "boolean" || e.isFunction(t)) return this.__toggle.apply(this, arguments); var n = i.apply(this, arguments); return n.mode = "toggle", this.effect.call(this, n) }, cssUnit: function(t) { var n = this.css(t), r = []; return e.each(["em", "px", "%", "pt"], function(e, t) { n.indexOf(t) > 0 && (r = [parseFloat(n), t]) }), r } }) } (), function() { var t = {}; e.each(["Quad", "Cubic", "Quart", "Quint", "Expo"], function(e, n) { t[n] = function(t) { return Math.pow(t, e + 2) } }), e.extend(t, { Sine: function(e) { return 1 - Math.cos(e * Math.PI / 2) }, Circ: function(e) { return 1 - Math.sqrt(1 - e * e) }, Elastic: function(e) { return e === 0 || e === 1 ? e : -Math.pow(2, 8 * (e - 1)) * Math.sin(((e - 1) * 80 - 7.5) * Math.PI / 15) }, Back: function(e) { return e * e * (3 * e - 2) }, Bounce: function(e) { var t, n = 4; while (e < ((t = Math.pow(2, --n)) - 1) / 11); return 1 / Math.pow(4, 3 - n) - 7.5625 * Math.pow((t * 3 - 2) / 22 - e, 2) } }), e.each(t, function(t, n) { e.easing["easeIn" + t] = n, e.easing["easeOut" + t] = function(e) { return 1 - n(1 - e) }, e.easing["easeInOut" + t] = function(e) { return e < .5 ? n(e * 2) / 2 : 1 - n(e * -2 + 2) / 2 } }) } () } (jQuery), function(e, t) { var n = 0, r = {}, i = {}; r.height = r.paddingTop = r.paddingBottom = r.borderTopWidth = r.borderBottomWidth = "hide", i.height = i.paddingTop = i.paddingBottom = i.borderTopWidth = i.borderBottomWidth = "show", e.widget("ui.accordion", { version: "1.9.0", options: { active: 0, animate: {}, collapsible: !1, event: "click", header: "> li > :first-child,> :not(li):even", heightStyle: "auto", icons: { activeHeader: "ui-icon-triangle-1-s", header: "ui-icon-triangle-1-e" }, activate: null, beforeActivate: null }, _create: function() { var t = this.accordionId = "ui-accordion-" + (this.element.attr("id") || ++n), r = this.options; this.prevShow = this.prevHide = e(), this.element.addClass("ui-accordion ui-widget ui-helper-reset"), this.headers = this.element.find(r.header).addClass("ui-accordion-header ui-helper-reset ui-state-default ui-corner-all"), this._hoverable(this.headers), this._focusable(this.headers), this.headers.next().addClass("ui-accordion-content ui-helper-reset ui-widget-content ui-corner-bottom").hide(), !r.collapsible && r.active === !1 && (r.active = 0), r.active < 0 && (r.active += this.headers.length), this.active = this._findActive(r.active).addClass("ui-accordion-header-active ui-state-active").toggleClass("ui-corner-all ui-corner-top"), this.active.next().addClass("ui-accordion-content-active").show(), this._createIcons(), this.originalHeight = this.element[0].style.height, this.refresh(), this.element.attr("role", "tablist"), this.headers.attr("role", "tab").each(function(n) { var r = e(this), i = r.attr("id"), s = r.next(), o = s.attr("id"); i || (i = t + "-header-" + n, r.attr("id", i)), o || (o = t + "-panel-" + n, s.attr("id", o)), r.attr("aria-controls", o), s.attr("aria-labelledby", i) }).next().attr("role", "tabpanel"), this.headers.not(this.active).attr({ "aria-selected": "false", tabIndex: -1 }).next().attr({ "aria-expanded": "false", "aria-hidden": "true" }).hide(), this.active.length ? this.active.attr({ "aria-selected": "true", tabIndex: 0 }).next().attr({ "aria-expanded": "true", "aria-hidden": "false" }) : this.headers.eq(0).attr("tabIndex", 0), this._on(this.headers, { keydown: "_keydown" }), this._on(this.headers.next(), { keydown: "_panelKeyDown" }), this._setupEvents(r.event) }, _getCreateEventData: function() { return { header: this.active, content: this.active.length ? this.active.next() : e()} }, _createIcons: function() { var t = this.options.icons; t && (e("").addClass("ui-accordion-header-icon ui-icon " + t.header).prependTo(this.headers), this.active.children(".ui-accordion-header-icon").removeClass(t.header).addClass(t.activeHeader), this.headers.addClass("ui-accordion-icons")) }, _destroyIcons: function() { this.headers.removeClass("ui-accordion-icons").children(".ui-accordion-header-icon").remove() }, _destroy: function() { var e; this.element.removeClass("ui-accordion ui-widget ui-helper-reset").removeAttr("role"), this.headers.removeClass("ui-accordion-header ui-accordion-header-active ui-helper-reset ui-state-default ui-corner-all ui-state-active ui-state-disabled ui-corner-top").removeAttr("role").removeAttr("aria-selected").removeAttr("aria-controls").removeAttr("tabIndex").each(function() { /^ui-accordion/.test(this.id) && this.removeAttribute("id") }), this._destroyIcons(), e = this.headers.next().css("display", "").removeAttr("role").removeAttr("aria-expanded").removeAttr("aria-hidden").removeAttr("aria-labelledby").removeClass("ui-helper-reset ui-widget-content ui-corner-bottom ui-accordion-content ui-accordion-content-active ui-state-disabled").each(function() { /^ui-accordion/.test(this.id) && this.removeAttribute("id") }), this.options.heightStyle !== "content" && (this.element.css("height", this.originalHeight), e.css("height", "")) }, _setOption: function(e, t) { if (e === "active") { this._activate(t); return } e === "event" && (this.options.event && this._off(this.headers, this.options.event), this._setupEvents(t)), this._super(e, t), e === "collapsible" && !t && this.options.active === !1 && this._activate(0), e === "icons" && (this._destroyIcons(), t && this._createIcons()), e === "disabled" && this.headers.add(this.headers.next()).toggleClass("ui-state-disabled", !!t) }, _keydown: function(t) { if (t.altKey || t.ctrlKey) return; var n = e.ui.keyCode, r = this.headers.length, i = this.headers.index(t.target), s = !1; switch (t.keyCode) { case n.RIGHT: case n.DOWN: s = this.headers[(i + 1) % r]; break; case n.LEFT: case n.UP: s = this.headers[(i - 1 + r) % r]; break; case n.SPACE: case n.ENTER: this._eventHandler(t); break; case n.HOME: s = this.headers[0]; break; case n.END: s = this.headers[r - 1] } s && (e(t.target).attr("tabIndex", -1), e(s).attr("tabIndex", 0), s.focus(), t.preventDefault()) }, _panelKeyDown: function(t) { t.keyCode === e.ui.keyCode.UP && t.ctrlKey && e(t.currentTarget).prev().focus() }, refresh: function() { var t, n, r = this.options.heightStyle, i = this.element.parent(); this.element.css("height", this.originalHeight), r === "fill" ? (e.support.minHeight || (n = i.css("overflow"), i.css("overflow", "hidden")), t = i.height(), this.element.siblings(":visible").each(function() { var n = e(this), r = n.css("position"); if (r === "absolute" || r === "fixed") return; t -= n.outerHeight(!0) }), n && i.css("overflow", n), this.headers.each(function() { t -= e(this).outerHeight(!0) }), this.headers.next().each(function() { e(this).height(Math.max(0, t - e(this).innerHeight() + e(this).height())) }).css("overflow", "auto")) : r === "auto" && (t = 0, this.headers.next().each(function() { t = Math.max(t, e(this).height("").height()) }).height(t)), r !== "content" && this.element.height(this.element.height()) }, _activate: function(t) { var n = this._findActive(t)[0]; if (n === this.active[0]) return; n = n || this.active[0], this._eventHandler({ target: n, currentTarget: n, preventDefault: e.noop }) }, _findActive: function(t) { return typeof t == "number" ? this.headers.eq(t) : e() }, _setupEvents: function(t) { var n = {}; if (!t) return; e.each(t.split(" "), function(e, t) { n[t] = "_eventHandler" }), this._on(this.headers, n) }, _eventHandler: function(t) { var n = this.options, r = this.active, i = e(t.currentTarget), s = i[0] === r[0], o = s && n.collapsible, u = o ? e() : i.next(), a = r.next(), f = { oldHeader: r, oldPanel: a, newHeader: o ? e() : i, newPanel: u }; t.preventDefault(); if (s && !n.collapsible || this._trigger("beforeActivate", t, f) === !1) return; n.active = o ? !1 : this.headers.index(i), this.active = s ? e() : i, this._toggle(f), r.removeClass("ui-accordion-header-active ui-state-active"), n.icons && r.children(".ui-accordion-header-icon").removeClass(n.icons.activeHeader).addClass(n.icons.header), s || (i.removeClass("ui-corner-all").addClass("ui-accordion-header-active ui-state-active ui-corner-top"), n.icons && i.children(".ui-accordion-header-icon").removeClass(n.icons.header).addClass(n.icons.activeHeader), i.next().addClass("ui-accordion-content-active")) }, _toggle: function(t) { var n = t.newPanel, r = this.prevShow.length ? this.prevShow : t.oldPanel; this.prevShow.add(this.prevHide).stop(!0, !0), this.prevShow = n, this.prevHide = r, this.options.animate ? this._animate(n, r, t) : (r.hide(), n.show(), this._toggleComplete(t)), r.attr({ "aria-expanded": "false", "aria-hidden": "true" }), r.prev().attr("aria-selected", "false"), n.length && r.length ? r.prev().attr("tabIndex", -1) : n.length && this.headers.filter(function() { return e(this).attr("tabIndex") === 0 }).attr("tabIndex", -1), n.attr({ "aria-expanded": "true", "aria-hidden": "false" }).prev().attr({ "aria-selected": "true", tabIndex: 0 }) }, _animate: function(e, t, n) { var s, o, u, a = this, f = 0, l = e.length && (!t.length || e.index() < t.index()), c = this.options.animate || {}, h = l && c.down || c, p = function() { a._toggleComplete(n) }; typeof h == "number" && (u = h), typeof h == "string" && (o = h), o = o || h.easing || c.easing, u = u || h.duration || c.duration; if (!t.length) return e.animate(i, u, o, p); if (!e.length) return t.animate(r, u, o, p); s = e.show().outerHeight(), t.animate(r, { duration: u, easing: o, step: function(e, t) { t.now = Math.round(e) } }), e.hide().animate(i, { duration: u, easing: o, complete: p, step: function(e, n) { n.now = Math.round(e), n.prop !== "height" ? f += n.now : a.options.heightStyle !== "content" && (n.now = Math.round(s - t.outerHeight() - f), f = 0) } }) }, _toggleComplete: function(e) { var t = e.oldPanel; t.removeClass("ui-accordion-content-active").prev().removeClass("ui-corner-top").addClass("ui-corner-all"), t.length && (t.parent()[0].className = t.parent()[0].className), this._trigger("activate", null, e) } }), e.uiBackCompat !== !1 && (function(e, t) { e.extend(t.options, { navigation: !1, navigationFilter: function() { return this.href.toLowerCase() === location.href.toLowerCase() } }); var n = t._create; t._create = function() { if (this.options.navigation) { var t = this, r = this.element.find(this.options.header), i = r.next(), s = r.add(i).find("a").filter(this.options.navigationFilter)[0]; s && r.add(i).each(function(n) { if (e.contains(this, s)) return t.options.active = Math.floor(n / 2), !1 }) } n.call(this) } } (jQuery, jQuery.ui.accordion.prototype), function(e, t) { e.extend(t.options, { heightStyle: null, autoHeight: !0, clearStyle: !1, fillSpace: !1 }); var n = t._create, r = t._setOption; e.extend(t, { _create: function() { this.options.heightStyle = this.options.heightStyle || this._mergeHeightStyle(), n.call(this) }, _setOption: function(e, t) { if (e === "autoHeight" || e === "clearStyle" || e === "fillSpace") this.options.heightStyle = this._mergeHeightStyle(); r.apply(this, arguments) }, _mergeHeightStyle: function() { var e = this.options; if (e.fillSpace) return "fill"; if (e.clearStyle) return "content"; if (e.autoHeight) return "auto" } }) } (jQuery, jQuery.ui.accordion.prototype), function(e, t) { e.extend(t.options.icons, { activeHeader: null, headerSelected: "ui-icon-triangle-1-s" }); var n = t._createIcons; t._createIcons = function() { this.options.icons && (this.options.icons.activeHeader = this.options.icons.activeHeader || this.options.icons.headerSelected), n.call(this) } } (jQuery, jQuery.ui.accordion.prototype), function(e, t) { t.activate = t._activate; var n = t._findActive; t._findActive = function(e) { return e === -1 && (e = !1), e && typeof e != "number" && (e = this.headers.index(this.headers.filter(e)), e === -1 && (e = !1)), n.call(this, e) } } (jQuery, jQuery.ui.accordion.prototype), jQuery.ui.accordion.prototype.resize = jQuery.ui.accordion.prototype.refresh, function(e, t) { e.extend(t.options, { change: null, changestart: null }); var n = t._trigger; t._trigger = function(e, t, r) { var i = n.apply(this, arguments); return i ? (e === "beforeActivate" ? i = n.call(this, "changestart", t, { oldHeader: r.oldHeader, oldContent: r.oldPanel, newHeader: r.newHeader, newContent: r.newPanel }) : e === "activate" && (i = n.call(this, "change", t, { oldHeader: r.oldHeader, oldContent: r.oldPanel, newHeader: r.newHeader, newContent: r.newPanel })), i) : !1 } } (jQuery, jQuery.ui.accordion.prototype), function(e, t) { e.extend(t.options, { animate: null, animated: "slide" }); var n = t._create; t._create = function() { var e = this.options; e.animate === null && (e.animated ? e.animated === "slide" ? e.animate = 300 : e.animated === "bounceslide" ? e.animate = { duration: 200, down: { easing: "easeOutBounce", duration: 1e3}} : e.animate = e.animated : e.animate = !1), n.call(this) } } (jQuery, jQuery.ui.accordion.prototype)) } (jQuery), function(e, t) { var n = 0; e.widget("ui.autocomplete", { version: "1.9.0", defaultElement: "", options: { appendTo: "body", autoFocus: !1, delay: 300, minLength: 1, position: { my: "left top", at: "left bottom", collision: "none" }, source: null, change: null, close: null, focus: null, open: null, response: null, search: null, select: null }, pending: 0, _create: function() { var t, n, r; this.isMultiLine = this._isMultiLine(), this.valueMethod = this.element[this.element.is("input,textarea") ? "val" : "text"], this.isNewMenu = !0, this.element.addClass("ui-autocomplete-input").attr("autocomplete", "off"), this._on({ keydown: function(i) { if (this.element.prop("readOnly")) { t = !0, r = !0, n = !0; return } t = !1, r = !1, n = !1; var s = e.ui.keyCode; switch (i.keyCode) { case s.PAGE_UP: t = !0, this._move("previousPage", i); break; case s.PAGE_DOWN: t = !0, this._move("nextPage", i); break; case s.UP: t = !0, this._keyEvent("previous", i); break; case s.DOWN: t = !0, this._keyEvent("next", i); break; case s.ENTER: case s.NUMPAD_ENTER: this.menu.active && (t = !0, i.preventDefault(), this.menu.select(i)); break; case s.TAB: this.menu.active && this.menu.select(i); break; case s.ESCAPE: this.menu.element.is(":visible") && (this._value(this.term), this.close(i), i.preventDefault()); break; default: n = !0, this._searchTimeout(i) } }, keypress: function(r) { if (t) { t = !1, r.preventDefault(); return } if (n) return; var i = e.ui.keyCode; switch (r.keyCode) { case i.PAGE_UP: this._move("previousPage", r); break; case i.PAGE_DOWN: this._move("nextPage", r); break; case i.UP: this._keyEvent("previous", r); break; case i.DOWN: this._keyEvent("next", r) } }, input: function(e) { if (r) { r = !1, e.preventDefault(); return } this._searchTimeout(e) }, focus: function() { this.selectedItem = null, this.previous = this._value() }, blur: function(e) { if (this.cancelBlur) { delete this.cancelBlur; return } clearTimeout(this.searching), this.close(e), this._change(e) } }), this._initSource(), this.menu = e("
" + (o[0] > 0 && I == o[1] - 1 ? '
' : "") : ""), F += U } B += F } return B += x + ($.browser.msie && parseInt($.browser.version, 10) < 7 && !e.inline ? '' : ""), e._keyEvent = !1, B }, _generateMonthYearHeader: function(e, t, n, r, i, s, o, u) { var a = this._get(e, "changeMonth"), f = this._get(e, "changeYear"), l = this._get(e, "showMonthAfterYear"), c = '
', h = ""; if (s || !a) h += '' + o[t] + ""; else { var p = r && r.getFullYear() == n, d = i && i.getFullYear() == n; h += '" } l || (c += h + (s || !a || !f ? " " : "")); if (!e.yearshtml) { e.yearshtml = ""; if (s || !f) c += '' + n + ""; else { var m = this._get(e, "yearRange").split(":"), g = (new Date).getFullYear(), y = function(e) { var t = e.match(/c[+-].*/) ? n + parseInt(e.substring(1), 10) : e.match(/[+-].*/) ? g + parseInt(e, 10) : parseInt(e, 10); return isNaN(t) ? g : t }, b = y(m[0]), w = Math.max(b, y(m[1] || "")); b = r ? Math.max(b, r.getFullYear()) : b, w = i ? Math.min(w, i.getFullYear()) : w, e.yearshtml += '", c += e.yearshtml, e.yearshtml = null } } return c += this._get(e, "yearSuffix"), l && (c += (s || !a || !f ? " " : "") + h), c += "
", c }, _adjustInstDate: function(e, t, n) { var r = e.drawYear + (n == "Y" ? t : 0), i = e.drawMonth + (n == "M" ? t : 0), s = Math.min(e.selectedDay, this._getDaysInMonth(r, i)) + (n == "D" ? t : 0), o = this._restrictMinMax(e, this._daylightSavingAdjust(new Date(r, i, s))); e.selectedDay = o.getDate(), e.drawMonth = e.selectedMonth = o.getMonth(), e.drawYear = e.selectedYear = o.getFullYear(), (n == "M" || n == "Y") && this._notifyChange(e) }, _restrictMinMax: function(e, t) { var n = this._getMinMaxDate(e, "min"), r = this._getMinMaxDate(e, "max"), i = n && t < n ? n : t; return i = r && i > r ? r : i, i }, _notifyChange: function(e) { var t = this._get(e, "onChangeMonthYear"); t && t.apply(e.input ? e.input[0] : null, [e.selectedYear, e.selectedMonth + 1, e]) }, _getNumberOfMonths: function(e) { var t = this._get(e, "numberOfMonths"); return t == null ? [1, 1] : typeof t == "number" ? [1, t] : t }, _getMinMaxDate: function(e, t) { return this._determineDate(e, this._get(e, t + "Date"), null) }, _getDaysInMonth: function(e, t) { return 32 - this._daylightSavingAdjust(new Date(e, t, 32)).getDate() }, _getFirstDayOfMonth: function(e, t) { return (new Date(e, t, 1)).getDay() }, _canAdjustMonth: function(e, t, n, r) { var i = this._getNumberOfMonths(e), s = this._daylightSavingAdjust(new Date(n, r + (t < 0 ? t : i[0] * i[1]), 1)); return t < 0 && s.setDate(this._getDaysInMonth(s.getFullYear(), s.getMonth())), this._isInRange(e, s) }, _isInRange: function(e, t) { var n = this._getMinMaxDate(e, "min"), r = this._getMinMaxDate(e, "max"); return (!n || t.getTime() >= n.getTime()) && (!r || t.getTime() <= r.getTime()) }, _getFormatConfig: function(e) { var t = this._get(e, "shortYearCutoff"); return t = typeof t != "string" ? t : (new Date).getFullYear() % 100 + parseInt(t, 10), { shortYearCutoff: t, dayNamesShort: this._get(e, "dayNamesShort"), dayNames: this._get(e, "dayNames"), monthNamesShort: this._get(e, "monthNamesShort"), monthNames: this._get(e, "monthNames")} }, _formatDate: function(e, t, n, r) { t || (e.currentDay = e.selectedDay, e.currentMonth = e.selectedMonth, e.currentYear = e.selectedYear); var i = t ? typeof t == "object" ? t : this._daylightSavingAdjust(new Date(r, n, t)) : this._daylightSavingAdjust(new Date(e.currentYear, e.currentMonth, e.currentDay)); return this.formatDate(this._get(e, "dateFormat"), i, this._getFormatConfig(e)) } }), $.fn.datepicker = function(e) { if (!this.length) return this; $.datepicker.initialized || ($(document).mousedown($.datepicker._checkExternalClick).find(document.body).append($.datepicker.dpDiv), $.datepicker.initialized = !0); var t = Array.prototype.slice.call(arguments, 1); return typeof e != "string" || e != "isDisabled" && e != "getDate" && e != "widget" ? e == "option" && arguments.length == 2 && typeof arguments[1] == "string" ? $.datepicker["_" + e + "Datepicker"].apply($.datepicker, [this[0]].concat(t)) : this.each(function() { typeof e == "string" ? $.datepicker["_" + e + "Datepicker"].apply($.datepicker, [this].concat(t)) : $.datepicker._attachDatepicker(this, e) }) : $.datepicker["_" + e + "Datepicker"].apply($.datepicker, [this[0]].concat(t)) }, $.datepicker = new Datepicker, $.datepicker.initialized = !1, $.datepicker.uuid = (new Date).getTime(), $.datepicker.version = "1.9.0", window["DP_jQuery_" + dpuuid] = $ } (jQuery), function(e, t) { var n = "ui-dialog ui-widget ui-widget-content ui-corner-all ", r = { buttons: !0, height: !0, maxHeight: !0, maxWidth: !0, minHeight: !0, minWidth: !0, width: !0 }, i = { maxHeight: !0, maxWidth: !0, minHeight: !0, minWidth: !0 }; e.widget("ui.dialog", { version: "1.9.0", options: { autoOpen: !0, buttons: {}, closeOnEscape: !0, closeText: "close", dialogClass: "", draggable: !0, hide: null, height: "auto", maxHeight: !1, maxWidth: !1, minHeight: 150, minWidth: 150, modal: !1, position: { my: "center", at: "center", of: window, collision: "fit", using: function(t) { var n = e(this).css(t).offset().top; n < 0 && e(this).css("top", t.top - n) } }, resizable: !0, show: null, stack: !0, title: "", width: 300, zIndex: 1e3 }, _create: function() { this.originalTitle = this.element.attr("title"), typeof this.originalTitle != "string" && (this.originalTitle = ""), this.oldPosition = { parent: this.element.parent(), index: this.element.parent().children().index(this.element) }, this.options.title = this.options.title || this.originalTitle; var t = this, r = this.options, i = r.title || " ", s = (this.uiDialog = e("
")).addClass(n + r.dialogClass).css({ display: "none", outline: 0, zIndex: r.zIndex }).attr("tabIndex", -1).keydown(function(n) { r.closeOnEscape && !n.isDefaultPrevented() && n.keyCode && n.keyCode === e.ui.keyCode.ESCAPE && (t.close(n), n.preventDefault()) }).mousedown(function(e) { t.moveToTop(!1, e) }).appendTo("body"), o = this.element.show().removeAttr("title").addClass("ui-dialog-content ui-widget-content").appendTo(s), u = (this.uiDialogTitlebar = e("
")).addClass("ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix").prependTo(s), a = e("").addClass("ui-dialog-titlebar-close ui-corner-all").attr("role", "button").click(function(e) { e.preventDefault(), t.close(e) }).appendTo(u), f = (this.uiDialogTitlebarCloseText = e("")).addClass("ui-icon ui-icon-closethick").text(r.closeText).appendTo(a), l = e("").uniqueId().addClass("ui-dialog-title").html(i).prependTo(u), c = (this.uiDialogButtonPane = e("
")).addClass("ui-dialog-buttonpane ui-widget-content ui-helper-clearfix"), h = (this.uiButtonSet = e("
")).addClass("ui-dialog-buttonset").appendTo(c); s.attr({ role: "dialog", "aria-labelledby": l.attr("id") }), u.find("*").add(u).disableSelection(), this._hoverable(a), this._focusable(a), r.draggable && e.fn.draggable && this._makeDraggable(), r.resizable && e.fn.resizable && this._makeResizable(), this._createButtons(r.buttons), this._isOpen = !1, e.fn.bgiframe && s.bgiframe(), this._on(s, { keydown: function(t) { if (!r.modal || t.keyCode !== e.ui.keyCode.TAB) return; var n = e(":tabbable", s), i = n.filter(":first"), o = n.filter(":last"); if (t.target === o[0] && !t.shiftKey) return i.focus(1), !1; if (t.target === i[0] && t.shiftKey) return o.focus(1), !1 } }) }, _init: function() { this.options.autoOpen && this.open() }, _destroy: function() { var e, t = this.oldPosition; this.overlay && this.overlay.destroy(), this.uiDialog.hide(), this.element.removeClass("ui-dialog-content ui-widget-content").hide().appendTo("body"), this.uiDialog.remove(), this.originalTitle && this.element.attr("title", this.originalTitle), e = t.parent.children().eq(t.index), e.length && e[0] !== this.element[0] ? e.before(this.element) : t.parent.append(this.element) }, widget: function() { return this.uiDialog }, close: function(t) { var n = this, r, i; if (!this._isOpen) return; if (!1 === this._trigger("beforeClose", t)) return; return this._isOpen = !1, this.overlay && this.overlay.destroy(), this.options.hide ? this.uiDialog.hide(this.options.hide, function() { n._trigger("close", t) }) : (this.uiDialog.hide(), this._trigger("close", t)), e.ui.dialog.overlay.resize(), this.options.modal && (r = 0, e(".ui-dialog").each(function() { this !== n.uiDialog[0] && (i = e(this).css("z-index"), isNaN(i) || (r = Math.max(r, i))) }), e.ui.dialog.maxZ = r), this }, isOpen: function() { return this._isOpen }, moveToTop: function(t, n) { var r = this.options, i; return r.modal && !t || !r.stack && !r.modal ? this._trigger("focus", n) : (r.zIndex > e.ui.dialog.maxZ && (e.ui.dialog.maxZ = r.zIndex), this.overlay && (e.ui.dialog.maxZ += 1, e.ui.dialog.overlay.maxZ = e.ui.dialog.maxZ, this.overlay.$el.css("z-index", e.ui.dialog.overlay.maxZ)), i = { scrollTop: this.element.scrollTop(), scrollLeft: this.element.scrollLeft() }, e.ui.dialog.maxZ += 1, this.uiDialog.css("z-index", e.ui.dialog.maxZ), this.element.attr(i), this._trigger("focus", n), this) }, open: function() { if (this._isOpen) return; var t, n = this.options, r = this.uiDialog; return this._size(), this._position(n.position), r.show(n.show), this.overlay = n.modal ? new e.ui.dialog.overlay(this) : null, this.moveToTop(!0), t = this.element.find(":tabbable"), t.length || (t = this.uiDialogButtonPane.find(":tabbable"), t.length || (t = r)), t.eq(0).focus(), this._isOpen = !0, this._trigger("open"), this }, _createButtons: function(t) { var n, r, i = this, s = !1; this.uiDialogButtonPane.remove(), this.uiButtonSet.empty(), typeof t == "object" && t !== null && e.each(t, function() { return !(s = !0) }), s ? (e.each(t, function(t, n) { n = e.isFunction(n) ? { click: n, text: t} : n; var r = e("